It’s happening. Bit by bit, little by little, I’m morphing from an engineer into some kind of…manager. Oh, don’t get me wrong, I still write code every day; ..
It’s happening. Bit by bit, little by little, I’ m morphing from an engineer into some kind of… manager. Oh, don’ t get me wrong, I still write code every day; but I find myself spending more and more time in analysis and discussion, in meetings and calls, making higher-level decisions, trying to organize teams, and worrying about strategy rather than tactics.
Of course this is no bad thing. Higher-level decisions tend to have far more impact than the nitty-gritty of individual classes and functions. Making a team more productive has much higher leverage than just making myself more productive. But I like to think I’ ve learned a few lessons from my years of writing code. I hope they’ ll mostly translate to managerdom. And I hope you’ ll pardon the implicit arrogance of sharing them with you:
1. There are no rules; there are only koans
Let me give you an example: DRY, aka “Don’ t Repeat Yourself.” It is so well understood as a fundamental rule of software that it often justifies decisions by itself; “I did X because DRY.” It makes sense, doesn’ t it? If you have two or more pieces of code which do the same thing, you are being wasteful, and furthermore, if you need to change one of them, you probably need to change the other, and you might forget, and when they get out of sync you’ ll get a weird bug, and… and it’s obvious that you don’ t repeat yourself.
And yet. After some years of applying that rule one begins to wonder about its universal applicability. Suppose you have two methods which contain the same block of code, so you pull that block out into a separate function. All too often, those methods then begin to evolve in divergent ways … so you find yourself adding more arguments to that function, and perhaps more flags to its results … and the coder who comes along next has the cognitive overhead of that separate function, with all its caller-specific arguments and results … and you realize that if you had let yourself repeat yourself, and had let those two blocks naturally grow into separate things, your resulting code would have been vastly simpler and more intuitive.
Does this mean DRY is bad? Of course not! DRY is correct.… Usually.… Under the appropriate circumstances.… Well, maybe. My personal rule of thumb is: “repeating yourself once is OK, more than once is not OK… but that depends on the context.” Because everything depends on the context. The purpose of DRY is not to DRY. If that is what you believe, grasshopper, you still have much to learn. The purpose of DRY is to make you think about DRY. There are no rules; there are only koans.
(Let me reiterate: I’ m talking about software. Hardware rules, in my experience, tend to actually be yes-we-mean-it rules. That’s pretty much why I got out of electrical engineering and into software.)
Consider two of my favorite “laws” of computer science. First: “There is no problem in computer science that cannot be solved by adding another layer of abstraction!” Is this true? Well, no, not literally. Is this frequently phenomenologically true? Well, actually, yeah. Does this mean abstraction is the right way to solve any problem? No it does not. It’s a koan. Brood on it.
And my all-time favorite: “The first law of optimization: don’ t do it. The second law of optimization (For Exports Only) : don’ t do it yet.” This of course is explicitly a koan, snarkily referring itself to a law. Is it time to make your code run faster? No. Is it time to make your code run faster? Not yet. What does this mean? It means consider the time, the complexity, the cognitive overhead, the tangible results, the overall goals, the meaning of life, the purpose of human existence. It means: meditate on it, grasshopper. But not for too long. We have work to do.
2. Earn trust by trusting
This doesn’ t just apply to managers, although it especially applies to managers, as trust is really the only thing of value that you have; if your fairness, your judgement, your understanding, your good faith, etc., are not trusted, then the rest of your organization will treat you as damage and route around you. Whereas if you’ re a capable but untrustworthy developer, you might still have some value, although it’ ll be much undercut by the effort spent riding herd on every decision you make.
The larger point is, though: a team needs to trust one another. When Natascia says, “I’ ll take care of that ticket, ” you have to trust that she will. When you say, “Peter can cut the build before the deadline, ” you have to trust that this is true. When someone says, “Listen, I have a crazy idea, ” they have to trust that they will be taken seriously and treated with respect, even if the idea is kinda crazy.
How do you build and earn trust? The answer is simplicity itself: you trust. You trust the person who says they can learn this new library and get it integrated by Monday. You trust the person who says they need to leave early and miss tomorrow’s standup because of a family thing. You trust the person who wants to take a week’s vacation a month before the hard deadline because they feel like they’ re beginning to burn out. You trust the junior developer who says they’ d like to take a crack at the hard problem.
You won’ t always be right. Sometimes people do in fact operate in bad faith, and you need to unveil those people and let them go as soon as possible. And sometimes you will trust people who will try in good faith to succeed… and they will fail. But — counterintuitively — this is usually a win, in the long run. Because those people will remember your trust, and they will do everything they can to pay it back with interest.
3. Simplicity is much more important than elegance
I mean, I get it. I love tight, elegant code too. And I love flexible frameworks with so many levels of abstraction that they’ re ready to handle, out of the box, whatever change request might be thrown at them. I like using bit vectors and bit shifts and slightly abstruse data structures and that quirky little language feature that isn’ t widely known but is so useful under these particular circumstances.
But you’ re not writing this code for yourself. Not even if it’s “just a prototype.” (I’ ve lost track of how many of my “prototypes” have wound up in production under a few layers of paint and polish.) And you’ re not just writing it to solve the current problem. You’ re writing it so the next developer who comes along can use it to solve the next problem. If those five lines of code would be understood more readily if they were ten lines of code, you know what, maybe fifteen would be better.
You can try and solve it for them in advance, with a flexible framework full of abstraction!… But maybe prophecy is not your strong suit; maybe your notion of what the next problem is completely off base. Maybe the best thing is just to make your code dead simple, with a naming convention and a coding style that makes it read almost like English. Maybe instead of adding another class, another file that the next developer has to keep open while trying to follow your flow of control, you should just do things the dumb way, the inelegant way, the simple way.
4. Momentum matters more than most things
We’ ve all seen it happen. One week everyone’s checking in code, the build is visibly taking shape, features are being added every day, test coverage keeps mounting higher and higher, Slack is alive with productive ideas and solutions. And the next week… somehow … things seem to have slowed down. A decision is needed on Issue A, which has knock-on effects on Issues B, C, and D, and while people can work on D, E, and F, they aren’ t part of the logical sequence of development; more assumptions have to be made, the cognitive load is higher, you have to mock out a bunch of things to get any non-mock code written at all. Somebody needs to make that decision.
Or maybe it’s not decision paralysis. Maybe all that progress you made last week was built on a false foundation of quick-hit technical debt, and you need to stop everything and go back and refactor it, and you need to do it now because the longer you wait, the worse things will get. Nobody wants to hear that. But they’ ll like hearing that now better than hearing that next month. Go tell them.
Or maybe last week was too much like crunch and now everybody’s just a little burnt out. You know what? Give them a day off. A whole day off. Each. It’ ll save you time in the long run, I promise.
It’s hard to define; it’s hard to measure; it’s hard to talk about. But momentum is a very real thing in software development, and its loss is a leading indicator of some kind of root trouble that needs to be addressed. Don’ t ignore it, and don’ t hope or pretend it will magically come back.