Practical
Code Reviews
Ilko Kacharov
Experience
Lead Dev @Proxiad / @Mailjet
12+ years in PHP
Zend Framework 2 Certified Architect
Engineer in communications
4+ years in Code reviews
Home
Shiny
Frontend
Messy
Backend
My Project is my Home
~8 hours a day
Clean and tidy
Secure and private
My Project is my Home
When you start a project you define the rules of the house.
Everyone who joins the project
should follow the rules!
My Project is my Home
Don't end up here
The housekeeper
Artwork by
Back in the days
2015+
Maintainability and Simplicity
Code management
2010
Code quality / style / standards, best practices
2005
Browser wars and internet revolution - Web 2.0
Why
do we need the process
- Reading code gets you in the mood for coding
- Keeps you up to date with the codebase
- Reduces back and forth with QA team
- Provides early feedback on the code
- Coding becomes social activity
- Starts discussions and generates ideas
What
- Code duplication
- Functionality duplication
- Introducing or reducing technical debt
- Bugs and inconsistencies
- Dependencies to libraries and repos
- Security and sensitive data protection
- Performance bottlenecks
- Maintainability
to look for in the code
Artwork by
When
You know the code
- Suggest architecture improvements
- Add code snippets (grabs attention, legitimacy, facts)
to comment the code
You don't know the code
- Ask for details or explanation (you might learn something)
- Too obvious things to ignore
Gut feelings & raised eyebrows
- Check your sources first (links & references to source code)
-
Uncontroversial approach
How
to be formally polite
Proposals
"We can use a tool instead of doing it manual."
"We better do filtering before we insert in the database."
"You can check if this code is available already."
Artwork by
How
to be formally polite
Questions
"We've changed this recently. Have you seen it?"
"Have you checked the code in the other module?"
"Is this code gonna be able to do the math if we pass 0?"
How
to be formally polite
Appeals
"Please verify that input, so we include all edge cases."
"Please use Оctocat memes when doing web presentations."
"Please add exclamation marks when code must be changed!"
Artwork by
How
to be formally polite
Positivity
"Good catch!"
"Clever approach!"
"Never knew code can do that!"
Artwork by
How
to be formally polite
Opinions are last
"I think this code already exists."
"I think we can do backflips instead."
The one who gives only opinion takes no responsibility.
To improve is to change
To perfect is to change often
Winston Churchill
«
»
Artwork by
Iterations and passes
- Daily code review routine
- Code review checklist for consistency
- Monitor and track security patterns
- Review individual commits on meaningful changes
- Early feedback on general issues
~ 40 lines
~ 200 lines
> 500 lines
First feedback at 30%
- Early feedback on the approach
- Focus on architecture decisions
- Skip minor details, code style
Second feedback at 90%
- Final touches
- Code style and trivial things
- Configurations and environment
Tools
-
Diff
-
History
-
Blame
-
Ignore whitespace
-
Ticket references #
-
Pre-commit hooks
-
Pull Requests
-
Labels (ask me later)
-
Code comments
-
Inline resolving of conflicts
-
Automatic code quality tools
-
Slack / Email notifications
to improve the process
Artwork by
Tools
to improve the process
Slack Notifications in #git-repo-name
Thank you!
@kachar136
https://slides.com/kachar/practical-code-reviews-bws/
Questions?
@kachar136
Thanks to GitHub.com for all the Octocats
Practical Code Reviews [BWS]
By Ilko Kacharov
Practical Code Reviews [BWS]
- 1,670