Autorelease
Release management for GitHub and continuous integration, based on branches.
The basic philosophy is to maintain development branches (which always have
development versions of the code) and release branches (which always have
release versions of the code). The workflow for a release is therefore:
- Update the version for release and make a PR to a stable branch; the top
post will be the release notes.
- Merge the PR.
That's it. Autorelease handles the rest.
When you make the PR to a stable branch, Autorelease will deploy the package to
testpypi, and re-download it and test it again. This ensures that you don't
publish broken packages. After you merge to the stable branch, Autorelease will
cut a new release on GitHub, and then publish the release on PyPI.
Tools included:
- Travis config imports and scripts to automatically test-deploy on testpypi,
then cut a GitHub release, then deploy to PyPI.
- Vendor-able GitHub Actions workflows for test-deploy, GitHub release, and
PyPI deploy.
- Vendor-able
version.py
that gives one true location for version
(setup.cfg
) while also enabling developer installs to give full and correct
version information. - Vendor-able
setup.py
that keeps all user-required information in the
setup.cfg
. - Script to draft release notes based on labels on merged PRs.
If you're a Python developer who uses Travis and GitHub, Autorelease handles
everything related to releasing to PyPI.