All code in Cesium is publicly peer reviewed. We review code to share knowledge, foster shared ownership, and improve code quality and consistency. Just knowing that code will be reviewed improves its quality.
This guide describes best practices for code reviews.
- GitHub has great tools for code reviews in pull requests. Become familiar with them.
- If we don't have a CLA for the contributor who opened the pull request (or, more precisely, any contributor to the branch), politely ask for one before reviewing the pull request (example).
- Most pull requests require additional work, often minor but sometimes major, before being merged. It's not a big deal. Sometimes we open a pull request with a task list for early feedback.
- Anyone is encouraged to review any pull request that interests them. However, someone familiar with the changed code should ultimately merge it.
- See the forest through the trees. Don't just review code one line at a time. Consider the big picture and its implications.
- Comments are about code, not the contributor who wrote the code. Don't be offended by a reviewer's comments and don't aim to offend when commenting. We all want the same thing: to improve Cesium.
- Provide motivation when it isn't obvious. Suggest why a change should be made.
- Point contributors to a relevant part of the Coding Guide when useful.
- Be concise. Make every word tell.
- Be responsive. The contributor should expect prompt feedback from reviewers, and reviewers should expect the same. If not, politely ask for it. We all want pull requests to get into master.
- Limit the scope. As a reviewer, it is easy to want to increase the scope, e.g., "why don't we do this everywhere?". These are often fair questions but can be better served by submitting a separate issue to allow more incremental pull requests.
- Bring others into the conversation sparingly. If someone has expertise with a particular language feature or problem domain under review, invite them to comment.
- If an experienced contributor makes a occasional whitespace or trivial mistake, just fix it to save on noise and speedup the review.
- If new identifiers were added to the public Cesium API:
- Verify there is new reference doc. See the Documentation Guide.
- Verify that CHANGES.md was updated.
- Does the change warrant a new Sandcastle example?
- Does it warrant a blog post or tweet so users know what to look forward to in the next release?
- Verify that deprecated and breaking changes to the public API were handled correctly. See the Deprecation Guide.
- Don't just review the code; test it by running the unit tests and relevant Sandcastle examples. See the Testing Guide.
- For some changes, it is useful to profile Cesium or step through the code in the debugger.
- Read the new reference doc. Build the reference doc if the changes are significant.
- Cesium uses Travis CI for continuous integration. Travis automatically builds Cesium, runs JSHint, and generates the documentation for each branch pushed to GitHub. Before merging a pull request, verify that all Travis checks pass, indicated by the green check-mark and green
Merge pull request
button:
- Delete the branch after merging the pull request.
- Verify that the corresponding issue (if any) was closed.
Sometimes it is useful to clean up the pull request. Here are some scenarios and how to tackle them. The tips below will use the following keywords:
- origin will refer to the user fork, ie.
[email protected]/username/cesium.git
. - upstream will refer to the AGI repo, ie.
[email protected]/AnalyticalGraphicsInc/cesium.git
. - mybranch will refer to your local branch name.
- target will refer to the target branch the PR is to be merged into (and also the source for
mybranch
).
If you are new to git, it may be useful to create a backup of your branch in case something goes wrong. To do that, use:
git branch # This should show that you are currently on "mybranch", otherwise use "git checkout mybranch"
git checkout -b mybranch-backup # This should change your current branch to "mybranch-backup", which should be identical to "mybranch"
# if you wish to be even more conservative, you can push this to remote
git push origin mybranch-backup
# Now switch back to your working "mybranch"
git checkout mybranch
git fetch --all # Ensures remote data is up to date
git merge origin/target # Merge the remote origin target with the local branch
git reset origin/target # This will reset your branch the same as origin/target, with your changes unstaged.
git add # Stage local changes, use `-u` for staging all tracked changes, `-p` to add interactively.
git commit -m "My single commit message"
git push -f origin mybranch # Requires force push as it is changing existing history on remote
There are 2 ways to do this, merge (recommended) and rebase (pretty).
The rule of thumb here is if you are working on a longer term feature branch that may have conflicts with the target branch, then it is best to merge.
If you are working on a a shorter pull request (like a bug fix) with a few commits that probably will not result in a conflict, then it is best to rebase.
When in doubt, merge.
Futher Reading: Merge vs Rebase.
With merge, your commits will become interleaved with other target branch commits based on timestamp.
git fetch --all # Fetch updates from all remotes
git merge upstream/target
git push origin mybranch # Does not require force push as it does not change history
With rebase, your commits will be added on top of the target branch and will look sequential.
git fetch --all # Fetch updates from all remotes
git rebase -i upstream/target
git push -f origin mybranch # Requires force push as it is changing existing history on remote