Before creating a new release please do a careful consideration about the version number for the new release. We are following Calendar Versioning and PEP440.
-
Install development dependencies
poetry install
-
Install twine for pypi package uploads
python3 -m pip install --user --upgrade twine
Note: This is only necessary for users performing the release process for the first time.
-
Create an account at Test PyPI.
-
Create an account at PyPI.
-
Create a pypi configuration file
~/.pypirc
with the following content (Note:<username>
must be replaced):[distutils] index-servers = pypi testpypi [pypi] username = <username> [testpypi] repository = https://test.pypi.org/legacy/ username = <username>
This step is only necessary if the token has to be created for the first time or if it has been lost.
-
Open Github Settings at https://github.com/settings/tokens
-
Create a new token
-
Copy token and store it carefully
-
Export token and GitHub user name in your current shell
export GITHUB_TOKEN=<token> export GITHUB_USER=<name>
-
Fetch upstream changes
git remote add upstream [email protected]:greenbone/gvm-tools.git git fetch upstream git rebase update/master
-
Get the current version number
poetry run python -m pontos.version show
-
Update the version number to some dev version e.g.
poetry run python -m pontos.version update 20.8.2dev1
-
Create a source and wheel distribution:
rm -rf dist build python_gvm.egg-info poetry build
-
Upload the archives in
dist
to Test PyPI:twine upload -r testpypi dist/*
-
Check if the package is available at https://test.pypi.org/project/gvm-tools.
-
Create a test directory:
mkdir gvm-tools-install-test cd gvm-tools-install-test python3 -m venv test-env source test-env/bin/activate pip install -U pip # ensure the environment uses a recent version of pip pip install --pre -I --extra-index-url https://test.pypi.org/simple/ gvm-tools
-
Check install version with a Python script:
python3 -c "from gvm import __version__; print(__version__)"
-
Remove test environment:
deactivate cd .. rm -rf gvm-tools-install-test
-
Run pontos-release prepare
poetry run pontos-release --release-version <version> --next-release-version <dev-version> --project gvm-tools --space greenbone --git-signing-key <your-public-gpg-key> --git-remote-name upstream prepare
-
Check git log and tag
git log -p # is the changelog correct? # does the version look right? # does the tag point to the correct commit?
-
If something did go wrong delete the tag, revert the commits and remove the temporary file for the release changelog
git tag -d v<version> git reset <last-commit-id-before-running-pontos-release> --hard rm .release.txt.md
-
Run pontos-release release
poetry run pontos-release --release-version <version> --next-release-version <dev-version> --project gvm-tools --space greenbone --git-signing-key <your-public-gpg-key> --git-remote-name upstream release
-
Uploading to PyPI is done automatically by pushing a git tag via CircleCI
-
Check if new version is available at https://pypi.org/project/gvm-tools.
-
Check the Github release: