Ok, this might be controversial. If code review in your team is mandatory, I think it causes more harm than benefits in the long run.
It's not an argument against code review in general. I think there's no denying that the practice of code review has numerous benefits.
But if you can't imagine your team operating without code review, you should probably reconsider your approach.
Mandatory code review is perfect for open source. When you have a bunch of strangers contributing changes to an open source project, it makes sense to require all the changes to be approved by the maintainer. The reason is that there is no trust between the maintainer and most contributors.
If you use the same process for code review inside your team, what does it say about the relationship between people? With an absence of trust being one of the biggest issues for teams, it's worth thinking about it for a while.
(Image source: The Five Dysfunctions of a Team)
Using the same tool/process for a completely different environment should always be done with extreme care.
I won't discuss typical problems with code review. Unnecessary discussions, arguing about style, waiting too long for the review… These are relatively easy to fix. But there's a bigger issue.
Mandatory code review is something that can hide other problems.
There's a bunch of issues, whose consequences can be somehow mitigated by code review:
This false sense of confidence is one of the most challenging things about code review. Because if these problems are there, not going through a code review process might actually uncover them. If a team notices that things got worse, they will probably quickly go back to requiring approval for each change.
That's why it's a controversial topic to talk about. With many great advantages of code review and many real-life stories of things going poorly when code review is missing, it's really hard to believe that it might be the code review itself which contributes to some of these problems.
If you cannot imagine working without code review, think hard about what is causing that. I believe that we should always work on the underlying issues and good fundamentals, instead of dealing with the symptoms.
Try to build trust, give your team members time to learn, improve your processes. I'm not saying that you should get rid of code review. But code review should be about collaboration, not verification.
If you rely on mandatory code review right now, I wouldn't recommend stopping it right now. But there are some things you can do to make your team rely on it less:
I believe these are low hanging fruit you can start doing with low cost and without much risk. They take some time, but the benefits come quickly (and are really long-lasting).
Trust is essential for good-performing teams. Processes and tools can be useful, but if we rely on them too much (and can't imagine working without them), it's always a sign of some underlying issues.
I hope you will try some of the things I mentioned and focus on building great fundamentals for your team.
If you don't agree with this article, though, please reach out! I would love to hear your thoughts on that subject.