Before starting the release process, verify the following:
- All work required for this release has been completed and the team is ready to release.
- All Github Actions Tests are green on main.
- The ReadtheDocs build for "latest" is marked as passed. To avoid mysterious errors, best practice is to empty your browser cache when reading new versions of the docs!
- The public documentation for the "latest" branch looks correct, and the release notes includes the last change which was made on
main
. - Get agreement on the version number to use for the release.
Woodwork uses semantic versioning. Every release has a major, minor and patch version number, and are displayed like so: <majorVersion>.<minorVersion>.<patchVersion>
.
If you'd like to create a development release, which won't be deployed to pypi and conda and marked as a generally-available production release, please add a "dev" prefix to the patch version, i.e. X.X.devX
. Note this claims the patch number--if the previous release was 0.12.0
, a subsequent dev release would be 0.12.dev1
, and the following release would be 0.12.2
, not 0.12.1
. Development releases deploy to test.pypi.org instead of to pypi.org.
- Branch off of Woodwork
main
and name the branch the release version number (e.g. release_0_13_3)
- Bump
__version__
insetup.py
,woodwork/version.py
, andwoodwork/tests/test_version.py
.
-
Replace "Future Release" in
docs/source/release_notes.rst
with the current date**v0.13.3 September 28, 2020**
-
Remove any unused Release Notes sections for this release (e.g. Fixes, Testing Changes)
-
Add yourself to the list of contributors to this release and put the contributors in alphabetical order
-
The release PR does not need to be mentioned in the list of changes
-
Add a commented out "Future Release" section with all of the Release Notes sections above the current section
.. **Future Release** * Enhancements * Fixes * Changes * Documentation Changes * Testing Changes .. Thanks to the following people for contributing to this release:
An example can be found here: alteryx#158
Checklist before merging:
- All tests are currently green on checkin and on
main
. - The ReadtheDocs build for the release PR branch has passed, and the resulting docs contain the expected release notes.
- PR has been reviewed and approved.
- Confirm with the team that
main
will be frozen until step 2 (Github Release) is complete.
After merging, verify again that ReadtheDocs "latest" is correct.
After the release pull request has been merged into the main
branch, it is time draft the github release. Example release
- The target should be the
main
branch - The tag should be the version number with a v prefix (e.g. v0.13.3)
- Release title is the same as the tag
- Release description should be the full Release Notes updates for the release, including the line thanking contributors. Contributors should also have their links changed from the docs syntax (:user:`gsheni`) to github syntax (@gsheni)
- This is not a pre-release
- Publishing the release will automatically upload the package to PyPI
- A bot should automatically create a new PR in conda-forge/woodwork-feedstock - note, the PR may take up to a few hours to be created
- Update requirements changes in
recipe/meta.yaml
(bot should have handled version and source links on its own) - After tests pass, a maintainer will merge the PR in