-
Notifications
You must be signed in to change notification settings - Fork 189
How to Review Pull Requests
David Humphrey edited this page Jan 15, 2021
·
1 revision
This is a checklist style approach to reviewing PRs in Telescope. It is based on the excellent code review guidelines at Google.
Google's "senior" rule for code review is also applicable to us:
Consider approving a change once it is definitely improving the overall code health, even if it isn’t perfect--you can iterate on it later. “There is no such thing as perfect code, only better code.”
We don't want to block work because it isn't perfect. File follow-up Issues and accept anything that pushes the project forward. We can do further fixes later.
- Examine the PR's structure. Is it done correctly? Does the title reflect what it's about? Is the description formatted correctly (e.g., "Closes #123", includes relevant sections)? If not, fix it, or ask the author to fix it.
- Read the PR's content. Does the description clearly discuss what this is fixing? Can you understand the problem, goals, and implementation? Is it clear what was changed? Ask questions for clarification if things aren't clear or obvious to you.
- Do we want to accept this PR? Is it necessary? Just because someone submits a fix or feature doesn't mean we need to take it. If the answer is 'no', can anything be done to change that to 'yes'? How will we work with the developer to deal with this?
- Confirm that CI is passing. Does the code pass linting, builds, unit tests, preview builds, etc. on all platforms? If it does not, figure out why, and fail the PR with a comment indicating why, and how to address things.
- Make sure you there are proper instructions for testing this change in the description. If you aren't clear how to run and test the fix, ask for clarification. The PR author should help you figure this out.
- Test the PR. This might involve running a preview build (e.g., frontend change), or you might have to pull the PR locally, build, and run it. The fix should solve the problem it was meant to address.
- Test edge cases. Does the solution work in a limited way, but break when you try it in some other context? For example, a frontend fix might work on desktop, but break on mobile. A backend change might break when run in Docker (i.e. production), but work on the author's machine. Try to exercise the fix in different ways to make sure that it does what it says, and doesn't regress or fail other parts of the code. If there are odd edge case failures, consider whether they need to be fixed in this PR or in a follow-up Issue. File new Issues for things that don't need to block this fix from landing.
- Examine the PR's code. Is it addressing the problem specified in the description? Is it touching files/lines unrelated to this fix? Could it be broken up into smaller pieces (e.g., separate PRs)? A change of a few hundred lines is OK, thousands of lines may not be. Does it included commented-out/dead code (it shouldn't)? Does it delete or add things unrelated to this fix?
- Read the PR's code line-by-line. Do you understand what everything is doing? Ask questions about lines that aren't clear (e.g., need comments to clarify, are overly clever and could be simplified, use poor coding practices, etc). Could we simplify or clean anything up?
- Check for tests. Does the PR include tests? Is it testable at all? Could we add them if they are missing? Do we need them to be added in this PR or a follow-up? If the tests are here, read them just like the rest of the code and make sure they aren't brittle and likely to break later on.
- Do we need to update our docs based on this change? Does this fix introduce a new workflow for developers? Does it change things for users? How will we capture this knowledge and communicate it to the rest of the team and/or userbase?
- Who else should review this code? Perhaps you are only comfortable doing some portion of the steps above. Are there other team members who could focus on specific aspects? For example, does it affect design, deployment, security, or some other area, where an expert should be called in? Find the right people to help you review this. Likely we need 2, 3, or more people looking at a PR.
- Is the code needing to be rebased? Are the commits a mess and needing to be cleaned up?
- Is the original developer willing to work with you to correct any issues in the PR? If not, who should take over this work?
Priorities
3.0 Milestone
3.0 Areas of interest by people
3.0 Discussion
Latest Triage meeting:
Older Triage meetings:
-
Add meetings to this list as they happen