wizzdev image

What are The Best Source Code review practices?

If there is a possibility of several things going wrong the one that will cause the most damage will be the one to go wrong. – Murphy

 

Code without defects does not exist. No matter how skilled and experienced a developer is, there will always be errors in the code. Only way to mitigate 

 

So what are code reviews?

Code reviews are methodical assessments of code designed to identify bugs, increase code quality, and help developers learn the source code.

 

Why do we need to do code reviews?

Firstly, to catch errors that are not noticed in the static analysis, unit tests, code format, code coverage, etc. Furthermore, to discuss the readability of the code. Also for the sake of the developers, in order to know the other parts of the system better. Finally, for  the developers to be able to learn from each other.

 

After a software developer has completed coding, a code review is an important step in the software development process. It provides a second opinion on the solution and implementation before it’s merged.

What are the typical mistakes in code reviews?

Focusing on errors that can be picked up in static analysis, unit tests, etc. Another mistake is overfocusing on secondary issues. There also might be too much code to review or the code might be accepted without checking.

There is also a psychological factor as a developer might be taking the review personally which might lead to quarrels and accusations.

 

But, how useful is code review?  Just look at the chart below.

Defect Density vs LOC chart

 

Defect density refers to the number of defects identified in a software component or code segment, divided by the size of that component. This measurement is typically expressed as defects per line of code (DPL)

Defect density plays a crucial role in software development. Firstly, it provides an objective measure of software quality that can be compared across different projects and teams. Secondly, defect density helps identify areas of the codebase that require further attention. Finally, defect density enables organizations to track and monitor the effectiveness of software development processes and quality improvement over time.

Defect Density vs Inspection rate chart

So, what should be our focus while reviewing code?

  • Whether the code meets the requirements
  • Whether the code is consistent with the overall design
  • Whether there are e.g. some hardware limitations
  • Whether the author had taken into account some edge cases
  • Whether the code is readable
  • Whether there are any concurrency issues
  • Whether there are any memory issues
  • Whether the code is duplicated

 

So, a checklist of things to do while reviewing code might look something like the below and include potential problems that can occur. Also, it needs to be up to date with the most common issues.

 

Checklist:

  • Most common issues
  • Verified feature requirements
  • Code readability
  • Coding Style
  • Clear naming
  • Code duplication
  • Tests
  • Documentation

Is there something else that could make the code review more efficient?

There are some things we can do, for example ask the author of the code to comment on it and obviously review it before handing it over to other developers. Another good idea is to have the code accepted by at least two reviewers. This should make the whole process much easier.

 

Recent entries

WizzDev Image

Does the use of AI violate copyrights?

The rise of AI has created new challenges for most industries. In the ever-present pursuit of expense cutting the use of pre-trained AI is rapidly reshaping all industries.  As Mercedes-Benz’s CEO,

wizzdev image

Why should we write unit tests?

If there is a possibility of several things going wrong, the one that will cause the most damage will be the one to go wrong. Corollary: If there is a worse

WizzDev Image

Does the use of AI violate copyrights?

The rise of AI has created new challenges for most industries. In the ever-present pursuit of expense cutting the use of pre-trained AI is rapidly reshaping all industries.  As Mercedes-Benz’s CEO,

wizzdev image

Why should we write unit tests?

If there is a possibility of several things going wrong, the one that will cause the most damage will be the one to go wrong. Corollary: If there is a worse

We use cookies to ensure that we give you the best experience on our website. If you continue to use this site we will assume that you are happy with it.