2014-09-24 11:17:04 +04:00
# Release Checklist
## Main Release
2015-04-03 16:54:55 +03:00
Released quarterly on the first day of January, April, July, October.
2014-09-24 11:17:04 +04:00
2015-04-03 17:51:57 +03:00
* [ ] Open a release ticket e.g. https://github.com/python-pillow/Pillow/issues/1174
2015-04-03 16:25:58 +03:00
* [ ] Develop and prepare release in ``master`` branch.
* [ ] Check [Travis CI ](https://travis-ci.org/python-pillow/Pillow ) to confirm passing tests in ``master`` branch.
2015-07-03 07:57:33 +03:00
* [ ] In compliance with https://www.python.org/dev/peps/pep-0440/, update version identifier in:
2015-04-02 22:11:39 +03:00
```
2015-10-05 12:36:25 +03:00
PIL/__init__.py setup.py _imaging.c appveyor.yml
2015-04-02 22:11:39 +03:00
```
* [ ] Update `CHANGES.rst` .
2015-10-01 18:29:19 +03:00
* [ ] Run pre-release check via `make release-test` in a freshly cloned repo.
2015-04-03 16:30:37 +03:00
* [ ] Create branch and tag for release e.g.:
```
$ git branch 2.9.x
$ git tag 2.9.0
$ git push --all
$ git push --tags
```
* [ ] Create and upload source distributions e.g.:
```
2015-10-02 00:04:09 +03:00
$ make sdist
$ make upload
2015-04-03 16:46:44 +03:00
```
2015-04-03 17:13:55 +03:00
* [ ] Create and upload [binary distributions ](#binary-distributions )
2015-10-02 01:44:39 +03:00
* [ ] Manually hide old versions on PyPI such that only the latest major release is visible when viewing https://pypi.python.org/pypi/Pillow (https://pypi.python.org/pypi?:action=pkg_edit& name=Pillow)
2014-09-24 11:17:04 +04:00
## Point Release
2015-04-03 17:12:13 +03:00
Released as needed for security, installation or critical bug fixes.
2015-04-02 22:11:39 +03:00
2015-04-03 17:12:13 +03:00
* [ ] Make necessary changes in ``master`` branch.
2015-07-03 07:57:33 +03:00
* [ ] Update `CHANGES.rst` .
2015-04-03 17:19:08 +03:00
* [ ] Cherry pick individual commits from ``master`` branch to release branch e.g. ``2.9.x``.
* [ ] Check [Travis CI ](https://travis-ci.org/python-pillow/Pillow ) to confirm passing tests in release branch e.g. ``2.9.x``.
2015-04-03 17:22:15 +03:00
* [ ] Checkout release branch e.g.:
```
git checkout -t remotes/origin/2.9.x
```
2015-07-03 07:57:33 +03:00
* [ ] In compliance with https://www.python.org/dev/peps/pep-0440/, update version identifier in:
2015-04-02 22:11:39 +03:00
```
2015-10-01 18:33:15 +03:00
PIL/__init__.py
setup.py
_imaging.c
appveyor.yml
2015-04-02 22:11:39 +03:00
```
2015-10-01 18:33:15 +03:00
* [ ] Run pre-release check via `make release-test` .
2015-04-03 17:19:08 +03:00
* [ ] Create tag for release e.g.:
```
2015-04-03 17:22:15 +03:00
$ git tag 2.9.1
2015-04-03 17:19:08 +03:00
$ git push --tags
```
2015-04-03 17:12:13 +03:00
* [ ] Create and upload source distributions e.g.:
```
$ make sdistup
```
2015-04-03 17:13:55 +03:00
* [ ] Create and upload [binary distributions ](#binary-distributions )
2015-04-03 17:19:08 +03:00
2014-09-24 11:17:04 +04:00
## Embargoed Release
2015-04-03 17:31:40 +03:00
Released as needed privately to individual vendors for critical security-related bug fixes.
2014-09-24 11:17:04 +04:00
* [ ] Prepare patch for all versions that will get a fix. Test against local installations.
* [ ] Commit against master, cherry pick to affected release branches.
* [ ] Run local test matrix on each release & Python version.
* [ ] Privately send to distros.
2015-10-01 18:33:15 +03:00
* [ ] Run pre-release check via `make release-test`
2014-09-24 11:17:04 +04:00
* [ ] Amend any commits with the CVE #
* [ ] On release date, tag and push to GitHub.
```
2015-04-03 16:55:43 +03:00
git checkout 2.5.x
git tag 2.5.3
git push origin 2.5.x
git push origin --tags
2014-09-24 11:17:04 +04:00
```
2015-04-03 17:26:35 +03:00
* [ ] Create and upload source distributions e.g.:
```
$ make sdistup
```
* [ ] Create and upload [binary distributions ](#binary-distributions )
2014-09-24 11:17:04 +04:00
2015-04-03 17:12:13 +03:00
## Binary Distributions
2014-09-24 11:17:04 +04:00
2015-04-03 18:00:47 +03:00
### Windows
* [ ] Contact @cgohlke for Windows binaries via release ticket e.g. https://github.com/python-pillow/Pillow/issues/1174.
* [ ] Download and extract tarball from @cgohlke and ``twine upload *``.
### OS X
* [ ] Use the [Pillow OS X Wheel Builder ](https://github.com/python-pillow/pillow-wheels ):
```
$ git checkout https://github.com/python-pillow/pillow-wheels
$ cd pillow-wheels
$ git submodule init
$ git submodule update
$ cd Pillow
$ git fetch --all
$ git commit -a -m "Pillow -> 2.9.0"
$ git push
2015-04-03 18:01:47 +03:00
```
2015-04-03 18:00:47 +03:00
* [ ] Download distributions from the [Pillow OS X Wheel Builder container ](http://cdf58691c5cf45771290-6a3b6a0f5f6ab91aadc447b2a897dd9a.r50.cf2.rackcdn.com/ ) and ``twine upload *``.
### Linux
## Publicize Release
2015-04-03 17:51:57 +03:00
2015-04-03 22:27:54 +03:00
* [ ] Announce release availability via [Twitter ](https://twitter.com/pythonpillow ) e.g. https://twitter.com/aclark4life/status/583366798302691328.
2015-09-30 15:43:21 +03:00
## Documentation
* [ ] Make sure the default version for Read the Docs is the latest release version e.g. 3.0.0 not latest: https://readthedocs.org/dashboard/pillow/versions/