Release #37
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Release | |
on: | |
workflow_dispatch: | |
jobs: | |
release: | |
runs-on: ubuntu-latest | |
steps: | |
- run: | | |
if [[ $GITHUB_REF_NAME != release/* ]]; then | |
echo this workflow should only be run against release branches | |
exit 1 | |
fi | |
- uses: actions/checkout@v4 | |
- name: Set environment variables | |
run: | | |
stable_version=$(./scripts/eachdist.py version --mode stable) | |
unstable_version=$(./scripts/eachdist.py version --mode prerelease) | |
if [[ $stable_version =~ ^([0-9]+)\.([0-9]+)\.([0-9]+) ]]; then | |
stable_major="${BASH_REMATCH[1]}" | |
stable_minor="${BASH_REMATCH[2]}" | |
stable_patch="${BASH_REMATCH[3]}" | |
else | |
echo "unexpected stable_version: $stable_version" | |
exit 1 | |
fi | |
if [[ $stable_patch != 0 ]]; then | |
if [[ $unstable_version =~ ^0\.([0-9]+)b([0-9]+)$ ]]; then | |
unstable_minor="${BASH_REMATCH[1]}" | |
unstable_patch="${BASH_REMATCH[2]}" | |
else | |
echo "unexpected unstable_version: $unstable_version" | |
exit 1 | |
fi | |
if [[ $unstable_patch != 0 ]]; then | |
prior_version_when_patch="$stable_major.$stable_minor.$((stable_patch - 1))/0.${unstable_minor}b$((unstable_patch - 1))" | |
fi | |
fi | |
echo "STABLE_VERSION=$stable_version" >> $GITHUB_ENV | |
echo "UNSTABLE_VERSION=$unstable_version" >> $GITHUB_ENV | |
echo "CHANGELOG=CHANGELOG.md" >> $GITHUB_ENV | |
echo "PRIOR_VERSION_WHEN_PATCH=$prior_version_when_patch" >> $GITHUB_ENV | |
- run: | | |
if [[ -z $PRIOR_VERSION_WHEN_PATCH ]]; then | |
# not making a patch release | |
if ! grep --quiet "^## Version ${STABLE_VERSION}/${UNSTABLE_VERSION} " CHANGELOG.md; then | |
echo the pull request generated by prepare-release-branch.yml needs to be merged first | |
exit 1 | |
fi | |
fi | |
# check out main branch to verify there won't be problems with merging the change log | |
# at the end of this workflow | |
- uses: actions/checkout@v4 | |
with: | |
ref: main | |
# back to the release branch | |
- uses: actions/checkout@v4 | |
# next few steps publish to pypi | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: '3.8' | |
- name: Build wheels | |
run: ./scripts/build.sh | |
- name: Install twine | |
run: | | |
pip install twine | |
# The step below publishes to testpypi in order to catch any issues | |
# with the package configuration that would cause a failure to upload | |
# to pypi. One example of such a failure is if a classifier is | |
# rejected by pypi (e.g "3 - Beta"). This would cause a failure during the | |
# middle of the package upload causing the action to fail, and certain packages | |
# might have already been updated, this would be bad. | |
# EDIT: 5/31/2024 - TestPypi now requires a verified email. Commenting out as a temporary measure | |
# until we found TestPypi credentials. | |
# - name: Publish to TestPyPI | |
# env: | |
# TWINE_USERNAME: '__token__' | |
# TWINE_PASSWORD: ${{ secrets.test_pypi_token }} | |
# run: | | |
# twine upload --repository testpypi --skip-existing --verbose dist/* | |
- name: Publish to PyPI | |
env: | |
TWINE_USERNAME: '__token__' | |
TWINE_PASSWORD: ${{ secrets.pypi_password }} | |
run: | | |
twine upload --skip-existing --verbose dist/* | |
- name: Generate release notes | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: | | |
echo "VERSION=${STABLE_VERSION}\/${UNSTABLE_VERSION}" >> $GITHUB_ENV | |
./scripts/generate_release_notes.sh | |
- name: Create GitHub release | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: | | |
gh release create --target $GITHUB_REF_NAME \ | |
--title "Version ${STABLE_VERSION}/${UNSTABLE_VERSION}" \ | |
--notes-file /tmp/release-notes.txt \ | |
--discussion-category announcements \ | |
v$UNSTABLE_VERSION | |
- uses: actions/checkout@v4 | |
with: | |
# the step below is creating a pull request against main | |
ref: main | |