Skip to content

Commit

Permalink
Merge pull request #9 from Deltares-research/feat/add-automated-relea…
Browse files Browse the repository at this point in the history
…se-workflow

feat(ci): Create release workflow
  • Loading branch information
LuukBlom authored Jan 13, 2025
2 parents 8bbf3e2 + b0287ed commit b982317
Showing 1 changed file with 164 additions and 0 deletions.
164 changes: 164 additions & 0 deletions .github/workflows/publish-to-pypi.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,164 @@
name: release

# This workflow will build a Python package and publish it to PyPI when a new tag is created.

# Usage:
# - Create a new tag with the version number in the format v*.*.* where * are integers: `git tag v1.2.3`
# - Push the tag to the repository: `git push origin tag v1.2.3`

# Result:
# - Check if the new version is greater than the latest version on PyPI
# - Install dependencies
# - Build the package
# - Publish it to PyPI
# - Create a GitHub release with the tag name and the release notes

# Checklist for using this workflow up for a new project:

# 1. In github settings:
# - Create an environment called `release`
# - Setup the permissions (https://github.com/<ORGANIZATION>/<REPO_NAME>/settings/environments)
# - Add the following variables:
# - PACKAGE_NAME: the name of your package on pypi
# - PYTHON_VERSION: the version of Python you want to use

# 2. On PyPi:
# - Create the project and add a trusted publisher (https://pypi.org/manage/project/<PACKAGE_NAME>/settings/publishing/ or https://pypi.org/manage/account/publishing if the project is not on pypi yet)
# - Ensure the publisher is configured to use:
# - the filename of this workflow yml (in this case: publish-to-pypi.yml)

# - In the `setup_and_build` job:
# - Update the the shell commands to install your package

on:
push:
tags:
- v[0-9]+\.[0-9]+\.[0-9]+
# https://peps.python.org/pep-0440/

jobs:
details:
runs-on: ubuntu-latest
outputs:
new_version: ${{ steps.release.outputs.new_version }}
tag_name: ${{ steps.release.outputs.tag_name }}
steps:
- uses: actions/checkout@v2

- name: Extract tag and Details
id: release
run: |
if [ "${{ github.ref_type }}" = "tag" ]; then
TAG_NAME=${GITHUB_REF#refs/tags/}
NEW_VERSION=$(echo $TAG_NAME | sed 's/^v//' | awk -F'-' '{print $1}')
echo "new_version=$NEW_VERSION" >> "$GITHUB_OUTPUT"
echo "tag_name=$TAG_NAME" >> "$GITHUB_OUTPUT"
echo "Version is $NEW_VERSION"
echo "Tag name is $TAG_NAME"
else
echo "No tag found"
exit 1
fi
check_pypi:
needs: details
runs-on: ubuntu-latest
steps:
- name: Fetch information from PyPI
run: |
response=$(curl -s https://pypi.org/pypi/${{ env.PACKAGE_NAME }}/json || echo "{}")
latest_previous_version=$(echo $response | jq --raw-output "select(.releases != null) | .releases | keys_unsorted[]" | sort -V | tail -n 1)
if [ -z "$latest_previous_version" ]; then
echo "Package not found on PyPI."
latest_previous_version="0.0.0"
fi
echo "Latest version on PyPI: $latest_previous_version"
echo "latest_previous_version=$latest_previous_version" >> $GITHUB_ENV
- name: Compare versions and exit if not newer
run: |
NEW_VERSION=${{ needs.details.outputs.new_version }}
LATEST_VERSION=$latest_previous_version
if [ "$(printf '%s\n' "$LATEST_VERSION" "$NEW_VERSION" | sort -rV | head -n 1)" != "$NEW_VERSION" ] || [ "$NEW_VERSION" == "$LATEST_VERSION" ]; then
echo "The new version $NEW_VERSION is not greater than the latest version $LATEST_VERSION on PyPI."
exit 1
else
echo "The new version $NEW_VERSION is greater than the latest version $LATEST_VERSION on PyPI."
fi
setup_and_build:
needs: [details, check_pypi]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4

- uses: conda-incubator/setup-miniconda@v3
with:
auto-update-conda: true
activate-environment: publish
python-version: ${{ env.PYTHON_VERSION }}
channels: conda-forge

- name: Install Build tools
shell: bash -el {0}
run: |
conda install -n publish pip setuptools wheel python-build
- name: Install dependencies
shell: bash -el {0}
run: |
conda run -n publish pip install .
- name: Build source and wheel distribution
run: |
conda run -n publish python -s -m build
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: dist
path: dist/

pypi_publish:
name: Upload release to PyPI
needs: [setup_and_build, details]
runs-on: ubuntu-latest
environment:
name: release

permissions:
id-token: write
steps:
- name: Download artifacts
uses: actions/download-artifact@v3
with:
name: dist
path: dist/

- name: Publish distribution to PyPI
uses: pypa/gh-action-pypi-publish@release/v1

github_release:
name: Create GitHub Release
needs: [setup_and_build, details]
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- name: Checkout Code
uses: actions/checkout@v3
with:
fetch-depth: 0

- name: Download artifacts
uses: actions/download-artifact@v3
with:
name: dist
path: dist/

- name: Create GitHub Release
id: create_release
env:
GH_TOKEN: ${{ github.token }}
run: |
gh release create ${{ needs.details.outputs.tag_name }} dist/* --title ${{ needs.details.outputs.tag_name }} --generate-notes

0 comments on commit b982317

Please sign in to comment.