From ce8d3d63147802899960ca261b4d34a5e0580cf2 Mon Sep 17 00:00:00 2001 From: Paul Hobson Date: Tue, 8 Oct 2024 09:37:26 -0700 Subject: [PATCH] document release process more; reactive GHAs on tag push --- .github/workflows/python-publish-pypi.yml | 3 +++ .github/workflows/python-publish-testpypi.yml | 3 +++ readme.md | 11 +++++++---- 3 files changed, 13 insertions(+), 4 deletions(-) diff --git a/.github/workflows/python-publish-pypi.yml b/.github/workflows/python-publish-pypi.yml index 3f62ea6..01f5af3 100644 --- a/.github/workflows/python-publish-pypi.yml +++ b/.github/workflows/python-publish-pypi.yml @@ -2,6 +2,9 @@ name: Publish Python 🐍 distribution 📦 to PyPI and TestPyPI on: workflow_dispatch: + push: + tags: # Pattern matched against refs/tags + - 'v*/release' # Push events to every that ends in /release jobs: build: diff --git a/.github/workflows/python-publish-testpypi.yml b/.github/workflows/python-publish-testpypi.yml index 69a8f8f..b9f09a4 100644 --- a/.github/workflows/python-publish-testpypi.yml +++ b/.github/workflows/python-publish-testpypi.yml @@ -2,6 +2,9 @@ name: Publish Python 🐍 distribution 📦 to TestPyPI on: workflow_dispatch: + push: + tags: # Pattern matched against refs/tags + - 'v*/test' # Push events to every that ends in /test jobs: build: diff --git a/readme.md b/readme.md index dece004..ba5f0d6 100644 --- a/readme.md +++ b/readme.md @@ -46,14 +46,17 @@ python check_wqio.py ## Releases +*First*, you need to bump all of the versions like in [this PR](https://github.com/International-BMP-Database/wqio/pull/194). + +After that is pushed/merged/fetched, it's time to tag the test and final releases. There are two Github actions that are run when tags are pushed. The first builds and uploads to TestPyPI if the tag is in the form `v../*/test`. The second builds, uploads to PyPI, then signs the release and creates a Github release with a bunch of different assets if the tag is in the form `v../release`. -To execute the builda, create a new tag ends with e.g., `/test` (i.e., `v0.6.3/test`) and push that. +To execute the builds, create a new tag ends with e.g., `/test` (i.e., `v0.6.3/test`) and push that. -If that works, create Yet Another tag that ends with `/release` (i.e., `v0.6.3/release`) and push that. +If that works, create Yet Another Tag that ends with `/release` (i.e., `v0.6.3/release`) and push that. All in all, that workflow looks like this: @@ -62,9 +65,9 @@ All in all, that workflow looks like this: git switch main git fetch upstream git merge --ff-only upstream/main -git tag -a "v0.6.4/test" # add comment in text editor +git tag -a "v0.6.4/test" # adjust version + add comment in text editor git push upstream --tags # watch, wait for CI to sucessfully build on TestPyPI -git tag -a "v0.6.4/release" # add comment in text editor +git tag -a "v0.6.4/release" # adjust version + add comment in text editor # watch, wait for CI to sucessfully build on actual PyPI ```