The Best Practices and Impact of Code Review on Productivity and Timelines
A 2022 survey of 1000+ tech professionals from companies of all sizes?found ?that 84 percent of businesses have a formalized process for code reviews. Out of these, 36 percent of the tech companies claimed that code reviews are the most remarkable technique to raise the quality of code.
Software engineers require efficient methods for writing, reviewing, and implementing consistently high-quality code. A thorough code review procedure can save the time and money wasted on faulty code, allowing engineers to work more productively and fostering a more effective team environment. With code review best practices, businesses can achieve a valuable and long-lasting competitive edge.
In this article, we will outline the best practices for code review and the impact of this procedure on productivity and timelines. Then, we will cover its incorporation into the development process and share some examples of successful code review implementation at Techstack,a?software engineering company ?that follows best practices of code review, bringing high standards to the tech industry.
Best Practices for Code Review
Maslov’s pyramid of code review has five layers. Each of them is a characteristic to which the reviewed code must conform. The bottom layer is the correctness of the code, which is of prime importance. Code review shouldn’t proceed to upper layers until the bottom layer, correctness, gets approved.
According to this principle, the code reviewer moves on, layer by layer, checking if the code is: secure, readable, elegant, and altruist.
How to Prepare Your Code for Review
One of the best practices for code review is thorough preparation. An author should prepare the code for review far before the procedure itself. They should plan and write the code with the reviewer in mind, saving them time and effort as much as possible. What can the author do to prepare the code for review?
Automate Whatever You Can
Automation is one of the best code review practices. The time of software engineers is precious. Therefore, automate every repetitive action of the engineer. Here is what a code author can delegate to machines:
No “By-the-Way” Changes
In code review best practices, a software engineer writing the code shouldn’t make any “by-the-way” changes. This means that the engineer should follow their task strictly and not change anything in the code they were not supposed to.
For example, if the task is to change the value from “true” to “false,” the engineer should do it. However, if during the task completion, they noticed a typo or a function that was not working and decided to change or delete it. In that case, it may cause changes in various files and misunderstandings for their code reviewer.
It doesn’t mean that the engineer writing the code has no right to improve their work environment. It implies that every change has to be systematized and make perfect sense for other engineers working on the product. Every “by-the-way” change has to be done as a new task.
Document Code
When Eugene Zarashaw, a Facebook Engineering Director, was asked about the organizational structure of Facebook and how the organization works, he said,?“Effectively, the code is its own design document often,”?meaning that the way to write and comment on the code is how it gets documented.
Therefore, software engineers shouldn’t be afraid to comment on their code, add good naming and structure, and update documentation, such as MD files, Confluence, etc., for their colleagues who will maintain the code. It is essential to understand that when an engineer writes code in any programming language, it should be well-written and structured to explain how it works and how to run the functions.
Smaller is Better
The golden rule of code reviews best practices is preparing the code for a code review to keep all pull requests smaller than 500 business code lines. Business code lines mean the code that will be run, read, and maintained by other engineers. It doesn’t include comments, new lines, different types of parenthesis, and different code formatting.
A pull request over 500 business code lines makes it very complicated for a code reviewer to analyze the code. In that case, a reviewer may ask for additional meetings to get explanations from the engineer who wrote the code. To avoid any possible complications, it is essential to decompose the code as early as possible. We recommend doing it during the planning instead of the development phase.
Author is the First Reviewer
The engineer who wrote the code is its first reviewer. Before transferring the code to another software engineer, the code's author should review it critically, abstracting from the fact that it is their code. The author should pretend that the code was written by someone else and not make any concessions during the code review.
Before assigning a code reviewer, an author should read and understand the code. If any questions arise, the author should find the answers to all of them. The author can write down these questions and answers as comments to the code, especially if the answer refers not only to this pull request but to the entire code in general.
Review Time
Optimizing review time is one of the best practices for code review. Both an author and a reviewer should value their time and make as many preparations as possible. In this case, the review can be conducted as swiftly as possible.
Respect Each Other
Code review is not a battle where a reviewer has a chance to criticize or humiliate an author. Both an author and a reviewer should see a code review as an opportunity to grow and improve their codebase and the quality of the code. Therefore, both sides should show respect to each other.
Code review should never turn into a fight, but should remain a discussion. It should be the task-oriented work of two peers. A reviewer should always work with a code, not with its author. Reviewer’s comments shouldn’t sound like blame, but like a proposal. They need to explain why they propose specific changes in the code and how these changes will improve it.
Set Clear Goals
Now, having discussed the core principles of a code review, it’s time to go back to Maslow’s pyramid of code review and describe it layer by layer. The bottom layer of the pyramid—correctness—has the highest priority. Every pull request has to reach a clear goal. Software engineers should understand that they write code to solve a particular problem. The following questions will help determine if the code meets the set goals.
Code Security
Security is the second layer of Maslow’s pyramid of code review. Every month, security breaches cause severe problems for organizations of all types and sizes. Only in the third quarter of 2022, due to data breaches,?15 million data records ?were exposed globally. Software engineers must understand the code's vulnerabilities and the security issues they must handle.
领英推荐
Readability is a Must
A software engineer doesn’t write code for a machine to read it once and forget. Code is written to be read by a human, not by a computer. Other engineers will have to maintain, read, and understand the code for a long time. Therefore, readability is a critical layer of the code review’s pyramid. The code must be written clearly and reflect exactly what is written in the business requirements.
Are You Proud of This Code?
When a reviewer approves the code, they take ownership of this code along with the author. Being proud of the code means wishing to share with your peers that you have worked on this code. It implies that the code is elegant, leverages well-known patterns, and handles the consistency between particular services and microservices.
What Improvements Does This Code Bring?
This question refers to the top layer of Maslow’s pyramid of the code review: altruism, a?selfless desire to work for the benefit of others. It is about evaluating the outcomes of a code review and?addressing technical debt that prevents businesses from growing . This layer implies answering the following questions:
The Impact of Code Review on Productivity and Timelines
The code review process has an overall positive impact on productivity and timelines. It aids in increasing code quality, discovering defects early, and decreasing the time spent on quality assurance. Code reviews help minimize the number of flaws and inconsistencies that otherwise are discovered only after the product release.
Knowing that a colleague will review the code, an author is likelier to write clean and concise code. It boosts the author’s productivity and saves the reviewer’s time. With the best practices for code review, another pair of eyes can catch minor flaws and patterns in the early stages. Leaving comments in the code for a reviewer makes it easier to recognize edge instances and saves time in investigating the case.
Code review best practices give software engineering teams a framework for discussing each other’s works and proposing changes. Code reviews help to maintain a consistent codebase and compliance with all applicable standards, regulations, and style guidelines. Therefore, this process speeds up the onboarding of new software engineers who benefit from knowledge sharing fostered by code reviews.
Incorporating Code Review into the Development Process
Code review is usually performed immediately after the author has written the code. It is normally placed between the “in progress” and “QA” columns. Code review has the following lifecycle:
First review.?The author should review their code themselves before assigning another software engineer to review it.
Examples of Successful Code Review
How To Delete a Non-Working Function Correctly?
If there is a need to delete a non-working function from the code, a review should make the following steps:
What if the Author of the Code Asks for a Review to Improve Their Code Because They Lack Knowledge?
If the author added a to-do comment for a reviewer, “make the code better because I don’t know how to,” the reviewer should proceed accordingly:
What to Do if a Reviewer is not an Expert in this Business Domain?
Excel in Your Code Quality with Techstack
Code review is an efficient method to achieve a consistently high quality of code. When performed following the best practices, this process helps your business save time and money otherwise spent on cleaning faulty code and fixing flaws and inconsistencies. Code reviews allow you to raise productivity and optimize timelines, giving your business a competitive edge in your industry.
Techstack is a full-stack software engineering company that follows the best code review practices to deliver high-quality standards of software product creation and?make an impact on the world . Our software engineers have extensive experience creating intricate solutions and customizing the development process.
Contact us ?to talk to our expert about code review best practices.
Source:?Techstack Ltd
Read more articles about software development solutions on our blog ??
Director of Software Development at Techstack | Mentor | Scrum Master
1 年Special thanks to Danylo Tolmachov for adding the "no by-the-way changes" point, which many developers constantly forget about.
Director of Software Development at Techstack | Mentor | Scrum Master
1 年I've always wanted to add another step to Maslow's pyramid of code review. I believe that, among other things, the code should also be logical. Sometimes you understand that the code does what it’s supposed to, but you don’t understand why this particular solution was chosen when there are other, simpler ways to solve the task.