2014-09-24 11:17:04 +04:00
# Release Checklist
2020-12-21 12:45:59 +03:00
See https://pillow.readthedocs.io/en/stable/releasenotes/versioning.html for
information about how the version numbers line up with releases.
2014-09-24 11:17:04 +04:00
## Main Release
2020-01-14 22:18:32 +03:00
Released quarterly on January 2nd, April 1st, July 1st and October 15th.
2014-09-24 11:17:04 +04:00
2018-07-06 01:27:01 +03:00
* [ ] Open a release ticket e.g. https://github.com/python-pillow/Pillow/issues/3154
2021-10-15 17:30:05 +03:00
* [ ] Develop and prepare release in `main` branch.
* [ ] Check [GitHub Actions ](https://github.com/python-pillow/Pillow/actions ) and [AppVeyor ](https://ci.appveyor.com/project/python-pillow/Pillow ) to confirm passing tests in `main` branch.
2020-12-18 10:51:13 +03:00
* [ ] Check that all of the wheel builds [Pillow Wheel Builder ](https://github.com/python-pillow/pillow-wheels ) pass the tests in Travis CI and GitHub Actions.
2023-04-08 18:59:44 +03:00
* [ ] In compliance with [PEP 440 ](https://peps.python.org/pep-0440/ ), update version identifier in `src/PIL/_version.py`
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.:
2019-01-06 18:05:52 +03:00
```bash
git branch 5.2.x
git tag 5.2.0
git push --tags
```
2020-10-15 14:39:49 +03:00
* [ ] Create and check source distribution:
2019-01-06 18:05:52 +03:00
```bash
make sdist
```
2021-10-15 17:30:05 +03:00
* [ ] Create [binary distributions ](https://github.com/python-pillow/Pillow/blob/main/RELEASING.md#binary-distributions )
2020-10-15 14:39:49 +03:00
* [ ] Check and upload all binaries and source distributions e.g.:
```bash
2022-04-01 11:15:09 +03:00
python3 -m twine check --strict dist/*
python3 -m twine upload dist/Pillow-5.2.0*
2020-10-15 14:39:49 +03:00
```
2020-11-27 07:12:14 +03:00
* [ ] Publish the [release on GitHub ](https://github.com/python-pillow/Pillow/releases )
2023-04-08 18:59:44 +03:00
* [ ] In compliance with [PEP 440 ](https://peps.python.org/pep-0440/ ),
2023-04-08 17:16:02 +03:00
increment and append `.dev0` to version identifier in `src/PIL/_version.py` and then:
```bash
git push --all
```
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
2021-10-15 17:30:05 +03:00
* [ ] Make necessary changes in `main` branch.
2015-07-03 07:57:33 +03:00
* [ ] Update `CHANGES.rst` .
2018-07-02 10:22:48 +03:00
* [ ] Check out release branch e.g.:
2019-01-06 18:05:52 +03:00
```bash
git checkout -t remotes/origin/5.2.x
```
2021-10-15 17:30:05 +03:00
* [ ] Cherry pick individual commits from `main` branch to release branch e.g. `5.2.x` , then `git push` .
2020-04-03 17:27:16 +03:00
2020-12-14 21:35:04 +03:00
* [ ] Check [GitHub Actions ](https://github.com/python-pillow/Pillow/actions ) and [AppVeyor ](https://ci.appveyor.com/project/python-pillow/Pillow ) to confirm passing tests in release branch e.g. `5.2.x` .
2023-04-08 18:59:44 +03:00
* [ ] In compliance with [PEP 440 ](https://peps.python.org/pep-0440/ ), update version identifier in `src/PIL/_version.py`
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.:
2019-01-06 18:05:52 +03:00
```bash
git tag 5.2.1
2020-04-03 17:27:34 +03:00
git push
2019-01-06 18:05:52 +03:00
git push --tags
```
2020-10-15 14:39:49 +03:00
* [ ] Create and check source distribution:
2019-01-06 18:05:52 +03:00
```bash
make sdist
```
2021-10-15 17:30:05 +03:00
* [ ] Create [binary distributions ](https://github.com/python-pillow/Pillow/blob/main/RELEASING.md#binary-distributions )
2020-10-15 14:39:49 +03:00
* [ ] Check and upload all binaries and source distributions e.g.:
```bash
2022-04-02 16:12:34 +03:00
python3 -m twine check --strict dist/*
2022-04-01 11:15:09 +03:00
python3 -m twine upload dist/Pillow-5.2.1*
2020-10-15 14:39:49 +03:00
```
2020-11-27 07:12:14 +03:00
* [ ] Publish the [release on GitHub ](https://github.com/python-pillow/Pillow/releases )
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.
2021-10-15 17:30:05 +03:00
* [ ] Commit against `main` , cherry pick to affected release branches.
2014-09-24 11:17:04 +04:00
* [ ] 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.
2019-01-06 18:05:52 +03:00
```bash
git checkout 2.5.x
git tag 2.5.3
git push origin 2.5.x
git push origin --tags
```
2020-10-15 14:39:49 +03:00
* [ ] Create and check source distribution:
2019-01-06 18:05:52 +03:00
```bash
make sdist
```
2021-10-15 17:30:05 +03:00
* [ ] Create [binary distributions ](https://github.com/python-pillow/Pillow/blob/main/RELEASING.md#binary-distributions )
2020-11-27 07:12:14 +03:00
* [ ] Publish the [release on GitHub ](https://github.com/python-pillow/Pillow/releases )
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
2023-04-08 17:11:20 +03:00
### macOS and Linux
2017-04-19 16:55:00 +03:00
* [ ] Use the [Pillow Wheel Builder ](https://github.com/python-pillow/pillow-wheels ):
2019-01-06 18:05:52 +03:00
```bash
git clone https://github.com/python-pillow/pillow-wheels
cd pillow-wheels
2019-03-03 04:56:30 +03:00
./update-pillow-tag.sh [[release tag]]
2019-01-06 18:05:52 +03:00
```
2020-10-15 14:39:49 +03:00
* [ ] Download wheels from the [Pillow Wheel Builder release ](https://github.com/python-pillow/pillow-wheels/releases )
2023-04-08 18:56:37 +03:00
and copy into `dist/` . For example using [GitHub CLI ](https://github.com/cli/cli ):
```bash
gh release download --dir dist --pattern "*.whl" --repo python-pillow/pillow-wheels
```
2015-04-03 18:00:47 +03:00
2023-04-08 17:11:20 +03:00
### Windows
* [ ] Download the artifacts from the [GitHub Actions "Test Windows" workflow ](https://github.com/python-pillow/Pillow/actions/workflows/test-windows.yml )
2023-04-09 22:39:24 +03:00
and copy into `dist/` . For example using [GitHub CLI ](https://github.com/cli/cli ):
2023-04-08 18:56:37 +03:00
```bash
gh run download --dir dist
# select dist-x.y.z
```
2023-04-08 17:11:20 +03:00
2015-04-03 18:00:47 +03:00
## Publicize Release
2015-04-03 17:51:57 +03:00
2023-01-05 01:56:59 +03:00
* [ ] Announce release availability via [Twitter ](https://twitter.com/pythonpillow ) and [Mastodon ](https://fosstodon.org/@pillow ) e.g. https://twitter.com/PythonPillow/status/1013789184354603010
2015-09-30 15:43:21 +03:00
## Documentation
2019-04-03 06:02:52 +03:00
* [ ] Make sure the [default version for Read the Docs ](https://pillow.readthedocs.io/en/stable/ ) is up-to-date with the release changes
2020-07-01 14:11:36 +03:00
## Docker Images
* [ ] Update Pillow in the Docker Images repository
```bash
git clone https://github.com/python-pillow/docker-images
cd docker-images
./update-pillow-tag.sh [[release tag]]
```