Skip to content

Latest commit

 

History

History
123 lines (76 loc) · 3.48 KB

release-procedure.md

File metadata and controls

123 lines (76 loc) · 3.48 KB

Release Procedure

The following procedures gives a short overview of what steps are needed to create a new release.

Prepare the Release

  1. Verify:

  2. Create a new branch release/<VERSION>.

  3. If one or several supported Python versions have been removed or added, verify that the 3 following files have been updated:

    • setup.cfg
    • tox.ini
    • .git/workflows/pythonpackage.yml
    • CITATION.cff
  4. Verify that the version has been updated and follow https://semver.org:

    • src/semver/__about__.py
    • docs/usage/semver-version.rst
  5. Add eventually new contributor(s) to CONTRIBUTORS.

  6. Check if all changelog entries are created. If some are missing, create them.

  7. Show the new draft CHANGELOG entry for the latest release with:

    $ tox -e changelog
    

    Check the output. If you are not happy, update the files in the changelog.d/ directory. If everything is okay, build the new CHANGELOG with:

    $ tox -e changelog -- build
    
  8. Build the documentation and check the output:

    $ tox -e docs
    
  9. Commit all changes, push, and create a pull request.

Create the New Release

  1. Ensure that long description (README.rst) can be correctly rendered by Pypi using restview --long-description

  2. Clean up your local Git repository. Be careful, as it will remove all files which are not versioned by Git:

    $ git clean -xfd
    

    Before you create your distribution files, clean the directory too:

    $ rm dist/*
    
  3. Create the distribution files (wheel and source):

    $ tox -e prepare-dist
    
  4. Upload the wheel and source to TestPyPI first:

    $ twine upload --repository-url https://test.pypi.org/legacy/  dist/*

    If you have a ~/.pypirc with a testpypi section, the upload can be simplified:

    $ twine upload --repository testpypi dist/*
    
  5. Check if everything is okay with the wheel. Check also the web site https://test.pypi.org/project/<VERSION>/

  6. If everything looks fine, merge the pull request.

  7. Upload to PyPI:

    $ git clean -xfd
    $ tox -e prepare-dist
    $ twine upload dist/*
  8. Go to https://pypi.org/project/semver/ to verify that new version is online and the page is rendered correctly.

Finish the release

  1. Create a tag:

    $ git tag -a x.y.z

    It's recommended to use the generated Tox output from the Changelog.

  2. Push the tag:

    $ git push origin x.y.z
  3. In GitHub Release page document the new release. Select the tag from the last step and copy the content of the tag description into the release description.

  4. Announce it in https://github.com/python-semver/python-semver/discussions/categories/announcements.

You're done! Celebrate!