The release procedure is a process in which different parts of the repository are involved.
These symbols help with orientation:
- 🐙 GitHub
- 💠 git (Bash)
- 📝 File
- 💻 Command Line (CMD)
This software follows the Semantic Versioning (SemVer).
It always has the format MAJOR.MINOR.PATCH
, for example 1.5.0
.
The data follows the Calendar Versioning (CalVer).
It always has the format YYYY-MM-DD
, for example 2022-05-16
.
Following the Semantic Versioning, different workflows for Major, Minor, or Patch
releases are possible.
For Major and Minor releases, follow the complete workflow.
For a Patch Release (Hotfix), start at section 3.
- Create New classic project
- Use the project template Automated kanban with reviews
- Named
super-repo-v0.1.0
- Add a meaningful description
- Track project progress
- Some days before the release, inform all developers
- Merge the open Pull Requests
- On release day, start the release early to ensure sufficient time for reviews
- Merge everything on the
develop
branch
- Use
📝issue_template_release
- Name
Release - Minor Version - 0.1.0
- Complete the necessary details
- Start here for a Patch Release (Hotfix)
- Draft a new release
- Enter the release version number
0.1.0
as title - Summarize key changes from changelog in the description
## [0.1.0] Minor Release - Name - Date
### Added
### Changed
### Removed
- Add a link to the
📝CHANGELOG.md
**Complete changelog:** [CHANGELOG.md](https://github.com/rl-institut/super-repo/blob/production/CHANGELOG.md)
- Add a link to compare versions
**Compare versions:** [0.1.0 - 0.2.0](https://github.com/rl-institut/super-repo/compare/v0.1.0...v0.2.0)
- Save draft
- Checkout
develop
and branch withgit checkout -b release-v0.1.0
- Push branch with
git push --set-upstream origin release-v0.1.0
- Run bumpversion 💻
bump-my-version bump --current-version 0.1.0 minor
📝CITATION.cff
- Update
version
- Update
date-released
- Update
📝pyproject.toml
- Update
version
- Update
📝uv.lock
- Update
version
- Update
- Update the
📝CHANGELOG.md
- Check that all Pull Request are included
- Rename
Unreleased
section with release title from issue - Follow
[0.0.0] Minor Release - Name of Release - 20YY-MM-DD
- Merge
release
intoproduction
branch - Remove details from template
- Assign two reviewers to check the release
- Run all test
- Execute the software locally
- Wait for reviews and tests
- Merge Pull Request and delete
release
branch
production
branch!
- Checkout
production
branch and pull - Check existing tags
git tag -n
- Create new tag:
git tag -a v0.1.0 -m "super-repo Minor Release v0.1.0"
- This commit will be the final version for the release, breath three times and check again
- Push tag:
git push --tags
If you messed up, remove tags and start again
- Delete local tag:
git tag -d v0.1.0
- Delete remote tag:
git push --delete origin v0.1.0
- Navigate to releases and open the draft release
- Choose the correct
Git Tag
- Choose the
production
branch - Select
Set as the latest release
- Select
Create a discussion for this release
in categoryAnnouncements
- Publish release
- Checkout
production
branch and pull - Activate environment and enter repository
- Test version with
mike serve
- Publish new minor version
mike deploy --push --update-aliases 0.1 latest
- Create a Pull Request from
production
todevelop
- Named
Set up new development after release v0.1.0
- Checkout
develop
branch and pull - Create a new Unreleased section in the
📝CHANGELOG.md
## [Unreleased]
### Added
### Changed
### Removed
- Check if the release it correctly displayed on Test-PyPI
- With each push to the release branch or the branch
test-release
the package is released on Test-PyPI by GitHub workflow (test-pypi-publish.yml).- Note: Pre-releases on Test-PyPI are only shown under
Release history
in the navigation bar. - Note: The branch status can only be released to a version on Test-PyPI once. Thus, for every branch status that you want to see on Test-PyPI increment the build version with
bump2version build
and push afterward.
- Note: Pre-releases on Test-PyPI are only shown under
- Once testing on Test-PyPI is done, change the release version to the final desired version with
bump2version release
- Note: The release on Test-PyPI might fail, but it will be the correct release version for the PyPI server.
- Push commits to the
release-*
branch
💻 cd D:\git\github\USER\Repository\
Navigate to git folder
💻 activate py310
Activate conda environment
💻 python -m build
Create package using
📝 dist
Check that files have been created in folder
💻 twine check dist/*
Check build
💻 twine upload -r testpypi dist/NAME_0.2.0.tar.gz
Upload to Test PyPI using
💻 twine upload dist/NAME_0.2.0.tar.gz
Upload to PyPI using
💻 Enter name
and password
🎉 Check on PyPI if release arrived, breath three times and smile!
!!! note "Used Icons" 🐙 GitHub | 💠 git | 📝 File | 💻 Command Line