Updates to pep 101 for GitHub-based releases
This commit is contained in:
parent
e505618795
commit
76f6614ff0
114
pep-0101.txt
114
pep-0101.txt
|
@ -39,10 +39,9 @@ Things You'll Need
|
||||||
and ``docs.iad1.psf.io``, the server that hosts the documentation.
|
and ``docs.iad1.psf.io``, the server that hosts the documentation.
|
||||||
You'll be uploading files directly here.
|
You'll be uploading files directly here.
|
||||||
|
|
||||||
* Shell access to ``hg.python.org``, the Python Mercurial host. You'll
|
* Admin access to ``https://github.com/python/cpython``
|
||||||
have to adapt repository configuration there.
|
|
||||||
|
|
||||||
* An administratior account on www.python.org, including an "API key".
|
* An administrator account on www.python.org, including an "API key".
|
||||||
|
|
||||||
* Write access to the PEP repository.
|
* Write access to the PEP repository.
|
||||||
|
|
||||||
|
@ -143,17 +142,14 @@ How to Make A Release
|
||||||
|
|
||||||
___ Make a release clone.
|
___ Make a release clone.
|
||||||
|
|
||||||
Create a local clone of the cpython repository (called the "release
|
On a fork of the cpython repository on GitHub, create a release branch
|
||||||
clone" from now on).
|
within it (called the "release clone" from now on). You can use the same
|
||||||
|
GitHub fork you use for cpython development. Using the standard setup
|
||||||
Also clone the repo at http://hg.python.org/cpython using the
|
recommended in the Python Developer's Guide, your fork would be referred
|
||||||
server-side clone feature. The name of the new clone should preferably
|
to as `origin` and the standard cpython repo as `upstream`. You will
|
||||||
have a "releasing/" prefix. The other experts will use the release
|
use the branch on your fork to do the release engineering work, including
|
||||||
clone for making the binaries, so it is important that they have access
|
tagging the release, and you will use it to share with the other experts
|
||||||
to it!
|
for making the binaries.
|
||||||
|
|
||||||
It's best to set up your local release clone to push to the remote
|
|
||||||
release clone by default (by editing .hg/hgrc to that effect).
|
|
||||||
|
|
||||||
___ Notify all committers by sending email to python-committers@python.org.
|
___ Notify all committers by sending email to python-committers@python.org.
|
||||||
|
|
||||||
|
@ -166,7 +162,7 @@ How to Make A Release
|
||||||
extra effort.
|
extra effort.
|
||||||
|
|
||||||
___ Make sure the current branch of your release clone is the branch you
|
___ Make sure the current branch of your release clone is the branch you
|
||||||
want to release from. (``hg id``)
|
want to release from. (``git status``)
|
||||||
|
|
||||||
___ Check the docs for markup errors.
|
___ Check the docs for markup errors.
|
||||||
|
|
||||||
|
@ -188,7 +184,7 @@ How to Make A Release
|
||||||
if there are differences, commit them.
|
if there are differences, commit them.
|
||||||
|
|
||||||
___ Make sure the SOURCE_URI in ``Doc/tools/extensions/pyspecific.py``
|
___ Make sure the SOURCE_URI in ``Doc/tools/extensions/pyspecific.py``
|
||||||
points to the right branch in the hg repository (or ``default`` for
|
points to the right branch in the git repository (or ``default`` for
|
||||||
unstable releases of the default branch).
|
unstable releases of the default branch).
|
||||||
|
|
||||||
___ Bump version numbers via the release script.
|
___ Bump version numbers via the release script.
|
||||||
|
@ -240,13 +236,14 @@ How to Make A Release
|
||||||
|
|
||||||
$ .../release-tools/release.py --tag X.Y.ZaN
|
$ .../release-tools/release.py --tag X.Y.ZaN
|
||||||
|
|
||||||
NOTE: when forward, i.e. "null" merging your changes to newer branches,
|
This executes a `git tag` command with the `-s` option so that the
|
||||||
e.g. 2.6 -> 2.7, do *not* revert your changes to the .hgtags file or you
|
release tag in the repo is signed with your gpg key. When prompted
|
||||||
will not be able to run the --export command below. Revert everything
|
choose the private key you use for signing release tarballs etc.
|
||||||
else but leave .hgtags alone.
|
|
||||||
|
|
||||||
___ If this is a final major release, branch the tree for X.Y.
|
___ If this is a final major release, branch the tree for X.Y.
|
||||||
|
|
||||||
|
This section has not yet been updated for GitHub-based releases!
|
||||||
|
|
||||||
When making a major release (e.g., for 3.2), you must create the
|
When making a major release (e.g., for 3.2), you must create the
|
||||||
long-lived maintenance branch.
|
long-lived maintenance branch.
|
||||||
|
|
||||||
|
@ -303,9 +300,15 @@ How to Make A Release
|
||||||
Also, update Doc/tools/templates/indexsidebar.html in all maintained
|
Also, update Doc/tools/templates/indexsidebar.html in all maintained
|
||||||
branches.
|
branches.
|
||||||
|
|
||||||
___ Push your commits to the remote release clone.
|
___ Push your commits to the remote release branch in your GitHub fork.
|
||||||
|
|
||||||
$ hg push ssh://hg.python.org/releasing/...
|
# Do a dry run first.
|
||||||
|
$ git push --dry-run origin
|
||||||
|
$ git push --dry-run --tags origin
|
||||||
|
# Make sure you are pushing to your GitHub fork, *not* to the main
|
||||||
|
# python/cpython repo!
|
||||||
|
$ git push origin
|
||||||
|
$ git push --tags origin
|
||||||
|
|
||||||
___ Notify the experts that they can start building binaries.
|
___ Notify the experts that they can start building binaries.
|
||||||
|
|
||||||
|
@ -360,9 +363,9 @@ How to Make A Release
|
||||||
___ Time to build the source tarball. Be sure to update your clone to the
|
___ Time to build the source tarball. Be sure to update your clone to the
|
||||||
correct branch. E.g.
|
correct branch. E.g.
|
||||||
|
|
||||||
$ hg update 3.2
|
$ git checkout 3.2
|
||||||
|
|
||||||
___ Do a "hg status" in this directory.
|
___ Do a "git status" in this directory.
|
||||||
|
|
||||||
You should not see any files. I.e. you better not have any uncommitted
|
You should not see any files. I.e. you better not have any uncommitted
|
||||||
changes in your working directory.
|
changes in your working directory.
|
||||||
|
@ -605,36 +608,53 @@ How to Make A Release
|
||||||
|
|
||||||
Now it's time to do some cleaning up. These steps are very important!
|
Now it's time to do some cleaning up. These steps are very important!
|
||||||
|
|
||||||
|
___ Temporarily disable others' pushes to the branch in the main cpython
|
||||||
|
repo and bypass the normal status checks. Go to the
|
||||||
|
Settings -> Branches page:
|
||||||
|
|
||||||
|
https://github.com/python/cpython/settings/branches/
|
||||||
|
|
||||||
|
and choose the Edit button for the branch you are working on.
|
||||||
|
On the Branch Protection page, check the "Restrict who can push to
|
||||||
|
this branch" box and add yourself. Also, uncheck the "Include
|
||||||
|
administrators" box and save changes.
|
||||||
|
|
||||||
|
___ Merge your release clone into the main development repo:
|
||||||
|
|
||||||
|
# Pristine copy of the upstream repo branch.
|
||||||
|
$ git clone --branch X.Y git@github.com:python/cpython.git merge
|
||||||
|
$ cd merge
|
||||||
|
# Fetch the newly created and signed tag from your repo
|
||||||
|
$ git fetch --tags git@github.com:your-github-id/cpython.git vX.Y.ZaN
|
||||||
|
# Null merge the temporary release branch discarding any changes
|
||||||
|
$ git merge --edit --no-squash -s ours vX.Y.ZaN
|
||||||
|
# Examine and update Misc/NEWS etc as needed. For example, you may
|
||||||
|
# need to move NEWS entries for cherry-picked items.
|
||||||
|
# Commit any changes.
|
||||||
|
$ git commit -m '...'
|
||||||
|
|
||||||
___ Do the guided post-release steps with the release script.
|
___ Do the guided post-release steps with the release script.
|
||||||
|
|
||||||
$ .../release-tools/release.py --done X.Y.ZaN
|
$ .../release-tools/release.py --done X.Y.ZaN
|
||||||
|
|
||||||
Review and commit these changes.
|
Review and commit these changes.
|
||||||
|
|
||||||
___ Merge your release clone into the main development repo:
|
|
||||||
|
|
||||||
$ cd ../cpython # your clone of the main repo
|
|
||||||
$ hg pull ssh://hg.python.org/cpython # update from remote first
|
|
||||||
$ hg pull ../cpython-releaseX.Y # now pull from release clone
|
|
||||||
|
|
||||||
Now merge your release clone's changes in every branch you touched
|
|
||||||
(usually only one, except if you made a new maintenance release).
|
|
||||||
Easily resolvable conflicts may appear in Misc/NEWS.
|
|
||||||
|
|
||||||
___ If releasing from other than the default branch, remember to carefully
|
|
||||||
merge any touched branches with higher level branches, up to default. For
|
|
||||||
example:
|
|
||||||
|
|
||||||
$ hg update -C default
|
|
||||||
$ hg resolve --list
|
|
||||||
$ hg merge --tool "internal:fail" 3.4
|
|
||||||
|
|
||||||
... here, revert changes that are not relevant for the default branch...
|
|
||||||
|
|
||||||
$ hg resolve --mark
|
|
||||||
|
|
||||||
___ Commit and push to the main repo.
|
___ Commit and push to the main repo.
|
||||||
|
|
||||||
|
# Do a dry run first.
|
||||||
|
$ git push --dry-run
|
||||||
|
$ git push --dry-run --tags
|
||||||
|
# If it looks OK, take the plunge. There's no going back from
|
||||||
|
# this step!
|
||||||
|
$ git push
|
||||||
|
$ git push --tags
|
||||||
|
|
||||||
|
___ Undo the temporary changes to the GitHub settings for the branch.
|
||||||
|
https://github.com/python/cpython/settings/branches/
|
||||||
|
|
||||||
|
Uncheck the "Retrict who can push to this branch". Check the "Include
|
||||||
|
administrators" box and save changes.
|
||||||
|
|
||||||
___ You can delete the remote release clone, or simply reuse it for the next
|
___ You can delete the remote release clone, or simply reuse it for the next
|
||||||
release.
|
release.
|
||||||
|
|
||||||
|
@ -643,7 +663,7 @@ How to Make A Release
|
||||||
|
|
||||||
___ Update any release PEPs (e.g. 361) with the release dates.
|
___ Update any release PEPs (e.g. 361) with the release dates.
|
||||||
|
|
||||||
___ Update the tracker at http://bugs.python.org:
|
___ Update the tracker at https://bugs.python.org:
|
||||||
|
|
||||||
___ Flip all the deferred blocker issues back to release blocker
|
___ Flip all the deferred blocker issues back to release blocker
|
||||||
for the next release.
|
for the next release.
|
||||||
|
|
Loading…
Reference in New Issue