The Good,
The Bad,
And the Code Review
data:image/s3,"s3://crabby-images/809f1/809f1f5a47a0d7c96cdeb31e4bb6cc4d47a87b07" alt=""
Manu Castrillón
Universidad de Antioquia
Medellín, Colombia
@manucastrillonm
data:image/s3,"s3://crabby-images/b65d6/b65d6bf7da2eac972fa10f291a5c31f854e40084" alt=""
A
Code
Review?
data:image/s3,"s3://crabby-images/5fc3d/5fc3de4c92a4f433735cf1022702a9f8dbba7bd0" alt=""
Benefits
data:image/s3,"s3://crabby-images/58540/5854022e25293934681ecd30213c593d66579bc2" alt=""
Learn and share
All the peers can explicitly know what functionalities are being added, updated or removed
@manucastrillonm
Raise team standards
Committers will tend to produce a better quality code, because they know someone else will be examining their work.
@manucastrillonm
Set the mindset for an open company culture
By introducing the process to give and to receive feedback in our natural daily workflow.
@manucastrillonm
Reduce the cost of fixing bugs
The cost of fixing a bug increases exponentially over the time in a development workflow
@manucastrillonm
data:image/s3,"s3://crabby-images/ead4e/ead4e47fe907d827974a32507c84394fdfd03880" alt=""
What
To
Look For
data:image/s3,"s3://crabby-images/1600f/1600f6c7fd02b616be79a14a8504ac8409678bcc" alt=""
- Design: Do the interactions of various pieces of code in the PR make sense?
- Functionality: Does this CL do what the developer intended?
- Complexity: Is the CL more complex than it should be?
- Tests: Ask for unit, integration, or end-to-end tests as appropriate for the change
@manucastrillonm
- Naming: Did the developer pick good names for everything?
- Comments: Did the developer write clear comments?
- Documentation: If a PR changes how users build, test, interact with, or release code, check to see that it also updates associated documentation.
@manucastrillonm
Good
Practices
data:image/s3,"s3://crabby-images/a7119/a71199ea253bb9193693a5e883c2b73182c74540" alt=""
For all
data:image/s3,"s3://crabby-images/014be/014bef4a201a97f6d263585c1f6fcefc6d133485" alt=""
Don't take things personally
Is not a "dev vs. peers"
@manucastrillonm
Use Checklists
"...we know, there are known knowns; there are things we know we know. We also know there are known unknowns; that is to say we know there are some things we do not know. But there are also unknown unknowns -- the ones we don't know we don't know."
- Donald Rumsfeld
@manucastrillonm
For committers
data:image/s3,"s3://crabby-images/457b0/457b01d14f3a0bd5ab28416b6cdbd96519e1cc23" alt=""
Provide context
-
Ensure your commit message explain what are you trying to achieve and how.
-
Link any related tickets or issues.
-
Comment your code.
@manucastrillonm
Keep the code short
Beyond 200 LOC the review effectiveness drop significantly, more than 400 it's almost pointless.
data:image/s3,"s3://crabby-images/56349/563497c8608055f147085b6fac6f4d529833eddf" alt=""
@manucastrillonm
Push commits based on earlier rounds of feedback as isolated commits to the branch
@manucastrillonm
For reviewers
data:image/s3,"s3://crabby-images/ec1a0/ec1a07b90820c56999955f1719adfba3ee58eb98" alt=""
You must understand the change you are reviewing
@manucastrillonm
Don't waste your time
There are plenty of tools for checking style and formatting issues.
@manucastrillonm
Everyone should review!
@manucastrillonm
Code review for short sessions
No longer than an hour
data:image/s3,"s3://crabby-images/7f5e2/7f5e2e52e4fbe7f4d62d29e8f54ebc52afb723d1" alt=""
@manucastrillonm
Reviews
Communication
data:image/s3,"s3://crabby-images/c3cd5/c3cd5a7637f18eb0464d299b30c7fef11210cad4" alt=""
For all
data:image/s3,"s3://crabby-images/014be/014bef4a201a97f6d263585c1f6fcefc6d133485" alt=""
-
Be humble
-
Keep it real
@manucastrillonm
For committers
data:image/s3,"s3://crabby-images/457b0/457b01d14f3a0bd5ab28416b6cdbd96519e1cc23" alt=""
-
Try to respond every comment
-
Be grateful for the reviewer's suggestions
@manucastrillonm
For reviewers
data:image/s3,"s3://crabby-images/ec1a0/ec1a07b90820c56999955f1719adfba3ee58eb98" alt=""
-
Judge the code, not the developer
-
The code is not 'his/her code' is 'our code'
-
Ask good questions. Don't make demands.
@manucastrillonm
Thank You
data:image/s3,"s3://crabby-images/c7ed8/c7ed85c562ca4260a1e02ec326341ef6a7097163" alt=""
@manucastrillonm
The good, the bad and the code review
By Manu Castrillón
The good, the bad and the code review
- 939