Code review, or PR review is the process of exchanging information and improving the code that is proposed to be included in the newer version of a software system until all parties involved are satisfied with the changes.
Code Review Aspects
- Design: Is it following the appropriate design pattern for the change involved?
- Functionality: Does the code behave as per the author's intention?
- Complexity: Is the implementation unnecessarily complex? Can another developer comprehend such implementations in the future?
- Tests: Does the code have sufficient tests that cover for most of the cases including edge cases?
- Naming: Is the naming for a variable, function or a class clear and cohesive?
- Comments: Are comments clear & useful? Try to avoid comments if possible.
- Style: Is the code following existing style guides?
- Documentation: Is the relevant documentation being updated?
- Improvements: Is the PR also improving existing codes altogether? "The boy scout rule"
- Consistency: Is the PR consistent with what we already have, such as naming, design patterns, etc.
Writing Descriptions
This part is applicable to the author. When creating a pull request for review, the description is a powerful tool to convey the whole context of the what and why effectively if utilized properly.
- Write a short summary that encompasses the whole idea of the pull request.
- Expand and elaborate on the summary and provide as much info as possible in a paragraph. If needed, use bullet points or numberings to list out the nitty gritty of the pull request.
- If the changes are related to user interface such as a new feature for a web application, provide appropriate screenshots and annotate each of them with easily-to-understand explanations.
- Provide any links or references that may be helpful.
A great description will fully prepare the reviewers for their expectations and give them a holistic view of the code changes.
Commenting
This part is applicable to the reviewer.
- Be respectful and constructive. Don't be harsh, judgemental, or sarcastic when reviewing someone else's code.
- Ask questions when having doubts about the code. The author should explain and justify why the code is written that way.
- Give suggestions when there is room for improvement on the code. Provide justifications, links, or references pertaining to the suggestion.
- Stop the reply chain. If a comment managed to garner a number of chained replies, and it seems to going nowhere, it indicates that the team have misunderstandings or misalignment. Offer a call separately to iron out the discrepancies to make sure that the team is on the same page. After clearing the doubts, come back to the same comment and post the final conclusion of the discussion so that other reviewers can be aligned.
For the authors, if you are offended by the reviewer's comment, take a step back and breathe. Don't take it personally. Lashing out in front of your co-workers is something that you will never want to happen. It is extremely immature and it will negatively impact your career and the relationship with the team in the long run. More often than not, the reviewers just want to make sure that the codebase to have the best quality and might be not good at putting words together such that it is deemed offensive when it actually isn't.
Take a deep deep breath
Other Tips
- Avoid huge PRs. Break it down into smaller, logical PRs to ease the review process. It is not a race to break your "Biggest PR ever created" record.
- Use conventional commits. Prefix each logical commit with appropriate terms so that each commits can be examined separately.
- Use conventional comments. This will prepare the author or anyone reading the comment on what to expect from it.
Summary
Code review ensures the quality of the codebase. It also helps the team to align with the changes, and make meaningful discussions for the win. Effective review fosters collaboration, not inciting hatred.