Differing Values In A Team Are Costly

submited by
Style Pass
2024-09-02 08:30:04

This post summarizes my takeaways from Platform as a Reflection of Values, a very eye-opening talk that helped me understand why I would have the same disagreements over and over with some team members in the past.

Both of us think tests are good! Both of us think that simple code is better than complicated code! To paraphrase Cantrill, nobody wakes up in the morning wanting their code to be slow, hard to read, hard to debug, brittle, and hard to test!

But while we both think that good things are good, our core values differ. What we spend our time thinking deeply about and pushing for differ. In practice this means that, when faced with choosing how to prioritize work, I won't choose what you would choose.

In this universe, you send in a bunch of code in a direct style. I have to go in and "fix" your code changes, adding dependency injection or splitting out I/O from logic to make it easier to test. In this process I introduce regressions (that weren't caught because rigorous tests weren't in place!)

In this same universe, you have gone from idea to code to "ready to deploy" more or less instantly. Your code doesn't have bugs. Not "I think there's no bugs" but there are no bugs. Yet my reply is to say "make this way less readable to prove the point." Insisting on introducing unit tests that "test the implementation". And at the end of all this some 5-line function is now a 25-line function with 2 levels of indirection hidden inside.

Leave a Comment