Making a new release of grave
ΒΆ
Update the release notes:
- Review and cleanup
doc/release/release_dev.rst
, - Fix code in documentation by running
cd doc && make doctest
. - Make a list of merges and contributors by running
doc/release/contribs.py <tag of previous release>
. - Paste this list at the end of the
release_dev.rst
. Scan the PR titles for highlights, deprecations, and API changes, and mention these in the relevant sections of the notes. - Rename to
doc/release/release_<major>.<minor>.rst
. - Copy
doc/release/release_template.rst
todoc/release/release_dev.rst
for the next release.
- Review and cleanup
Commit changes.
Add the version number as a tag in git:
git tag -s [-u <key-id>] networkx-<major>.<minor>
(If you do not have a gpg key, use -m instead; it is important for Debian packaging that the tags are annotated)
Push the new meta-data to github:
git push --tags upstream master
- (where
upstream
is the name of the github.com:networkx/networkx
repository.)
- (where
Review the github release page:
https://github.com/networkx/grave/releases
Publish on PyPi:
git clean -fxd python setup.py sdist --formats=zip twine upload -s dist/grave*.zip
Update documentation on the web: The documentation is kept in a separate branch: gh-pages
Wait for the Grave Travis Bot to deploy to GitHub Pages
Sync your branch with the remote repo:
git pull
.Copy the documentation built by Travis. Assuming you are at the top-level of the
gh-pages
branch:cp -a latest <major>.<minor> git add <major>.<minor> ln -sfn <major>.<minor> stable git commit -m "Add <major>.<minor> docs" # maybe squash all the Deploy GitHub Pages commits # git rebase -i HEAD~XX where XX is the number of commits back # check you didn't break anything # diff -r latest networkx-<major>.<minor> # you will then need to force the push so be careful! git push
- Increase the version number
- Update the web frontpage:
The webpage is kept in a separate branch: website
- Sync your branch with the remote repo:
git pull
. If you try togit push
when your branch is out of sync, it creates headaches. - Update
_templates/sidebar_versions.html
. - Edit
_static/docversions.js
and commit - Push your changes to the repo.
- Deploy using
git push
.
- Sync your branch with the remote repo:
- Post release notes on mailing list.