βRemember, code is your house, and you have to live in it.β - Michael Feathers π
— Programming Wisdom (@CodeWisdom) April 19, 2017
This is the best metaphor I know for promoting or defending software quality.
We do live in our codebases: shoddy software engineering has direct, easily-visualised analogues from construction and house maintenance.
For instance, I’m sure you’ve seen these pull requests before1:
data:image/s3,"s3://crabby-images/3c94e/3c94e96cdf77405f480c37699fc74295d4dc1b3d" alt="Bricks"
data:image/s3,"s3://crabby-images/62b92/62b921e359764e3842523a3081b90ade68d90b7d" alt="Fan"
Furthermore, the episode “Hurrican Neddy” from season 8 of The Simpsons is a parable of a failed software project, where feature delivery is prioritised at the expense of maintainability.
data:image/s3,"s3://crabby-images/33872/338725e65ad9c00ff77100c30b7f9f0c6798a890" alt="Hurricane Neddy"
data:image/s3,"s3://crabby-images/4afe1/4afe1e6989f5d66a87aaeb87d74167eebef7ac43" alt="Hurricane Neddy"
data:image/s3,"s3://crabby-images/b376a/b376a47acd45600a58d6cb1dfc1f3ee522096771" alt="Hurricane Neddy"
Homer: Your beautiful kitchen, Ned, just as you remember it.
Ned: Was that, uh, was that toilet always next to the refrigerator?
I often think of the toilet in the kitchen often when reviewing code, when an issue is addressed by shoving code into a place where it really doesn’t belong.
It’s a useful metaphor - it will serve you well in the struggle to keep a large codebase maintainable2.
data:image/s3,"s3://crabby-images/0daeb/0daebeec2e8eba9f1e08918bf9fd05a47a5a040c" alt="This is fine"
-
I first saw the fan image in a tweet by @isoiphone. I can’t find the tweet I saw the bricks image in - please let me know if you know it. ↩︎
-
Anthropomorphic dog image from a Gunshow strip called “On Fire” ↩︎