Simplified and updated committing code guidelines.

This commit is contained in:
Tim Graham 2015-02-17 15:32:47 -05:00
parent 0adf766e16
commit dbacbc729a
1 changed files with 43 additions and 40 deletions

View File

@ -12,7 +12,7 @@ who wants to contribute code to Django, have a look at
Handling pull requests Handling pull requests
---------------------- ----------------------
Since Django is now hosted at GitHub, many patches are provided in the form of Since Django is now hosted at GitHub, most patches are provided in the form of
pull requests. pull requests.
When committing a pull request, make sure each individual commit matches the When committing a pull request, make sure each individual commit matches the
@ -29,58 +29,57 @@ to standard themselves.
.. _Jenkins wiki page: https://code.djangoproject.com/wiki/Jenkins .. _Jenkins wiki page: https://code.djangoproject.com/wiki/Jenkins
Here is one way to commit a pull request:: An easy way to checkout a pull request locally is to add an alias to your
``~/.gitconfig`` (``upstream`` is assumed to be ``django/django``)::
# Create a new branch tracking upstream/master -- upstream is assumed [alias]
# to be django/django. pr = !sh -c \"git fetch upstream pull/${1}/head:pr/${1} && git checkout pr/${1}\"
git checkout -b pull_xxxxx upstream/master
# Download the patches from github and apply them. Now you can simply run ``git pr ####`` to checkout the corresponding pull
curl https://github.com/django/django/pull/xxxxx.patch | git am request.
At this point, you can work on the code. Use ``git rebase -i`` and ``git At this point, you can work on the code. Use ``git rebase -i`` and ``git
commit --amend`` to make sure the commits have the expected level of quality. commit --amend`` to make sure the commits have the expected level of quality.
Once you're ready:: Once you're ready:
# Make sure master is ready to receive changes. .. code-block:: console
git checkout master
git pull upstream master
# Merge the work as "fast-forward" to master, to avoid a merge commit.
git merge --ff-only pull_xxxxx
# Check that only the changes you expect will be pushed to upstream.
git push --dry-run upstream master
# Push!
git push upstream master
# Get rid of the pull_xxxxx branch. $ # Pull in the latest changes from master.
git branch -d pull_xxxxx $ git checkout master
$ git pull upstream master
$ # Rebase the pull request on master.
$ git checkout pr/####
$ git rebase master
$ git checkout master
$ # Merge the work as "fast-forward" to master to avoid a merge commit.
$ # (in practice, you can omit "--ff-only" since you just rebased)
$ git merge --ff-only pr/XXXX
$ # If you're not sure if you did things correctly, check that only the
$ # changes you expect will be pushed to upstream.
$ git push --dry-run upstream master
$ # Push!
$ git push upstream master
$ # Delete the pull request branch.
$ git branch -d pr/xxxx
An alternative is to add the contributor's repository as a new remote, For changes on your own branches, force push to your fork after rebasing on
checkout the branch and work from there:: master but before merging and pushing to upstream. This allows the commit
hashes on master and your branch to match which automatically closes the pull
request. Since you can't push to other contributors' branches, comment on the
pull request "Merged in XXXXXXX" (replacing with the commit hash) after you
merge it. Trac checks for this message format to indicate on the ticket page
whether or not a pull request is merged.
git remote add <contributor> https://github.com/<contributor>/django.git Avoid using GitHub's "Merge pull request" button on the Web site as its creates
git checkout pull_xxxxx <contributor> <contributor's pull request branch> an ugly "merge commit" and makes navigating history more difficult.
Yet another alternative is to fetch the branch without adding the
contributor's repository as a remote::
git fetch https://github.com/<contributor>/django.git <contributor's pull request branch>
git checkout -b pull_xxxxx FETCH_HEAD
At this point, you can work on the code and continue as above.
GitHub provides a one-click merge functionality for pull requests. This should
only be used if the pull request is 100% ready, and you have checked it for
errors (or trust the request maker enough to skip checks). Currently, it isn't
possible to check that the tests pass and that the docs build without
downloading the changes to your development environment.
When rewriting the commit history of a pull request, the goal is to make When rewriting the commit history of a pull request, the goal is to make
Django's commit history as usable as possible: Django's commit history as usable as possible:
* If a patch contains back-and-forth commits, then rewrite those into one. * If a patch contains back-and-forth commits, then rewrite those into one.
Typically, a commit can add some code, and a second commit can fix For example, if a commit adds some code and a second commit fixes stylistic
stylistic issues introduced in the first commit. issues introduced in the first commit, those commits should be squashed
before merging.
* Separate changes to different commits by logical grouping: if you do a * Separate changes to different commits by logical grouping: if you do a
stylistic cleanup at the same time as you do other changes to a file, stylistic cleanup at the same time as you do other changes to a file,
@ -93,7 +92,7 @@ Django's commit history as usable as possible:
tests nor the docs should emit warnings. tests nor the docs should emit warnings.
* Trivial and small patches usually are best done in one commit. Medium to * Trivial and small patches usually are best done in one commit. Medium to
large work should be split into multiple commits if possible. large work may be split into multiple commits if it makes sense.
Practicality beats purity, so it is up to each committer to decide how much Practicality beats purity, so it is up to each committer to decide how much
history mangling to do for a pull request. The main points are engaging the history mangling to do for a pull request. The main points are engaging the
@ -196,6 +195,10 @@ Django's Git repository:
Backport of 80c0cbf1c97047daed2c5b41b296bbc56fe1d7e3 from master. Backport of 80c0cbf1c97047daed2c5b41b296bbc56fe1d7e3 from master.
There's a `script on the wiki
<https://code.djangoproject.com/wiki/CommitterTips#AutomatingBackports>`_
to automate this.
Reverting commits Reverting commits
----------------- -----------------