A PR review guideline
This is a set of sources/articles that can be used to:
- learn what standards PRs should meet
- learn how you or your colleagues should handle PR reviews
- reference on a PR that your comments/requirements are not only your wannabe but a general standard for code reviews in the IT industry
Standards
Go
Naming
Common Mistakes
data:image/s3,"s3://crabby-images/6c087/6c08775668edf36e532ec15c134b65a76e5cc05a" alt=""
Baseline
data:image/s3,"s3://crabby-images/6c087/6c08775668edf36e532ec15c134b65a76e5cc05a" alt=""
data:image/s3,"s3://crabby-images/6c087/6c08775668edf36e532ec15c134b65a76e5cc05a" alt=""
Style Guide
100 Go Mistakes
data:image/s3,"s3://crabby-images/0d652/0d65209dc7c41a099d396ebb91088fe3a6ffa3f4" alt=""
Reviewer checklist
Many times, I struggled to get a quality review on a PR. I knew my code was not documented enough, not optimized, complicated, or... not understood by the reviewer, and I still got approval to merge that. It is pure frustration that we spent hours trying to make something work, giving our all to craft a PR, only to have it flash before someone's eyes when they click "Approve."
> [!IMPORTANT]
> Dear Reviewer, please go through the below checklist:
> - [ ] Ensure you fully understand the changes in this PR, and ask for clarification if anything is unclear.
> - [ ] Verify that the changes align with the PR description and follow coding best practices.
> - [ ] Look for areas of improvement in readability, maintainability, performance, and security.
> - [ ] Check if tests are sufficient, the commit structure is logical, and no unintended side effects exist.
> - [ ] Run necessary tests, review documentation, and ensure the PR is good for merging. 🚀
What's more, I will share a cheat with you, you can save that checklist as Saved reply.
Navigate to Github Settings page and select Saved replies.
data:image/s3,"s3://crabby-images/b47bd/b47bda3f6f3521a5eb5d1094acedd1bb06c903f4" alt=""
And add a checklist there:
data:image/s3,"s3://crabby-images/d5e80/d5e809d58bda2854d9c128e0cd3646e172772b50" alt=""
It is saved now:
data:image/s3,"s3://crabby-images/1e50f/1e50f34a637209fd23baedc343e771429374f688" alt=""
So you can use it in PR description using /
like this:
data:image/s3,"s3://crabby-images/cf324/cf324c333abfb14e8edce2c63866c92668521a0f" alt=""
data:image/s3,"s3://crabby-images/5ba65/5ba65e2b3bd11b29749e9bb08ac6f9b088e9ba46" alt=""