Your codebase is your garden
I always liked the your codebase is like a garden
metaphor, it says that writing software is like gardening, you have to take care of your garden in many ways and from time to time you have to move plants around relative to each other, consider how to take advantage of the wind, rain and sunlight to help your plants grow and stay healthy. Every day you have to monitor them and make adjustments as needed. Like your code. But how can we do it in practice and become good gardeners?
Refacto-what?
The first very pragmatic case where we can find the word refactor
is during the TDD cycle: Red -> Green -> Refactor.
We have a specific step where we have to focus on making our code cleaner and better.
This part is so importat that we need to separate it from the implementation part. It’s like we are wearing two hats. The first hat is for the implementation; creating and adding code. The second hat is about improving it.
Essentially:
Rewriting, reworking and re-architecting code is called refactoring.
But remember, when we talk about refactoring we assume that we don’t change our code’s behaviour. We are wearing another hat.
So when should I refactor?
There’s not a specific rule for it, but I usually try to follow these points:
Duplication
I always try to follow the DRY principle or when duplicating is necessary I try to follow the three-strikes rule.
I suppose that how to spot a duplication is just a matter of practice. I found myself after many years of experience having a good sense of spotting duplications so my advice is to practice more.
Non-orthogonal design
Non-orthogonality means that modifying a component has another effect somewhere else. For example, modifying the UI of our application results in a need to change our database too.
When we say that two components are orthogonal to each other, it means that if we make some changes to a component, they don’t affect other components.
Outdated knowledge
The nature of our software is evolving over time, so we have to update business and validation rules. Our needs change and so does our software.
Performance
Of course, if we can improve our software’s performance in terms of using the right data structures or a better algorithm, we should do so as much as we can.
Practice makes perfect
Identifying these smells is a matter of experience. My advice is to do some katas on refactoring, you can find many of them online, for example, the trip service kata by Sandro Mancuso or the tennis-refactoring kata by Emily Bache.
Try to follow the boy scout’s rule also known as Opportunistic Refactoring by Martin Fowler as much as you can and take notes of the most common smells you have in your codebase, trying to avoid reproducing them next time.
How to convince your boss that you have to fix your roses
The example I like most is a medical one and I think it fits very well:
let’s think about our need to refactor as growth. Removing it requires invasive surgery, we can remove it now spending some time while it’s small or we could wait until it grows. Then will be more expensive and dangerous and waiting even longer could bring our patient to death.
But I think the most important thing to mention to your boss is about economics. Martin Fowler talked about the Design Stamina Hypothesis, which show us that a clean and well-maintained codebase help us to deliver more features faster; answering to the question should I refactor my code?
Sometimes it’s difficult to find time to do a refactoring that could take days to be finished so often we think that there will be a better time to do our refactoring and find an excuse to avoid it. But trust me, finding the right time later is difficult and often it never happen. In my team, for example, we thought about a basic solution: use a tech-debt dashboard.
Every sprint we put a tech-debt task on our board in order to be sure to allocate some time to do something we left behind avoiding to let it grow. This is also called Planned Refactoring, it’s still a smell but sometimes is a necessary evil.
General advice
To maintain our garden beautiful and flourishing we should follow these steps as much as we can
- Refactor early
- Refactor often
- Keep track of the things that need to be refactored
- Take small reasonable steps. Make localized changes
- Don’t try to refactor and add functionality at the same time
- Make sure you have good regression tests, this is important to have enough confidence to refactor freely
- Run tests as often as possible
- Have fun
Happy gardening!
Resources
- During this quarantine I found myself re-reading The Pragmatic Programmer, a book which I strongly suggest to read at least once. Per year.
- Of course, I think all of us should have watched Martin Fowler’s talk about the refactoring’s workflow
- Read the Refactoring book by Martin Fowler
- Watch Sandro Mancuso’s video about testing and refactoring legacy code