From 8c2adcde9e11bb4530ea9db84f4d06d8fd16a8d8 Mon Sep 17 00:00:00 2001 From: Peter Kok Date: Thu, 15 Aug 2024 13:19:29 +0200 Subject: [PATCH] Update CI/CD workflows Copied from paradigma-shell and tsdf --- .github/workflows/build-and-test.yml | 81 +++++++++++++++++++ .github/workflows/ci.yml | 42 ---------- .github/workflows/publish.yml | 115 +++++++++++++++++++++++++++ 3 files changed, 196 insertions(+), 42 deletions(-) create mode 100644 .github/workflows/build-and-test.yml delete mode 100644 .github/workflows/ci.yml create mode 100644 .github/workflows/publish.yml diff --git a/.github/workflows/build-and-test.yml b/.github/workflows/build-and-test.yml new file mode 100644 index 0000000..2c2a2a1 --- /dev/null +++ b/.github/workflows/build-and-test.yml @@ -0,0 +1,81 @@ +# This workflow will install Python dependencies, run tests and lint with a variety of Python versions +# For more information see: https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions + +name: Build and test + +on: + push: + branches: [ main ] + pull_request: + branches: [ main ] + workflow_call: + outputs: + version: + description: "The version retrieved from the pyproject.toml file." + value: ${{ jobs.build-and-test.outputs.version }} + +jobs: + build-and-test: + + runs-on: ubuntu-latest + strategy: + matrix: + python-version: ['3.9'] + outputs: + version: ${{ steps.get_version.outputs.version }} + + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: Set up Python ${{ matrix.python-version }} + uses: actions/setup-python@v5 + with: + python-version: ${{ matrix.python-version }} + + # Get the version from pyproject.toml + # This will be used to tag the release in the publishing workflow + - name: Install toml package + run: pip install toml + - name: Get version from pyproject.toml + id: get_version + run: | + VERSION=$(python -c "import toml; print(toml.load('pyproject.toml')['tool']['poetry']['version'])") + echo Version: $VERSION + echo "version=$VERSION" >> $GITHUB_OUTPUT + + # Installation + - name: Install dependencies + run: | + python -m pip install poetry + poetry install + + # Testing and checking + - name: Test with pytest + run: | + poetry run pytest + # - name: Type check + # run: | + # poetry run pytype . + + # Build the package + - name: Build the package + run: | + poetry build + - name: Archive build artifacts + uses: actions/upload-artifact@v4 + if: github.ref == 'refs/heads/release' + with: + name: build-artifacts + path: dist/ + + # Build the docs + - name: Build the docs + run: | + poetry run make html --directory docs + - name: Archive documentation + uses: actions/upload-artifact@v4 + if: github.ref == 'refs/heads/release' + with: + name: docs-html + path: docs/build/html/ diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml deleted file mode 100644 index 9ce4aa0..0000000 --- a/.github/workflows/ci.yml +++ /dev/null @@ -1,42 +0,0 @@ -name: ci - -on: - push: - branches: - - main - pull_request: - branches: - - main - - -jobs: - ci: - # Set up operating system - runs-on: ubuntu-latest - - # Define job steps - steps: - - name: Set up Python - uses: actions/setup-python@v4 - with: - python-version: "3.9" - - - name: Check-out repository - uses: actions/checkout@v3 - - - name: Install poetry - uses: snok/install-poetry@v1 - - - name: Install package - run: poetry install - - - name: Test with pytest - run: poetry run pytest tests/ --cov=paradigma --cov-report=xml - - - name: Use Codecov to track coverage - uses: codecov/codecov-action@v3 - with: - files: ./coverage.xml # coverage report - - - name: Build documentation - run: poetry run make html --directory docs/ diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml new file mode 100644 index 0000000..9db8dd7 --- /dev/null +++ b/.github/workflows/publish.yml @@ -0,0 +1,115 @@ +# Sources: +# https://packaging.python.org/en/latest/guides/publishing-package-distribution-releases-using-github-actions-ci-cd-workflows/#workflow-definition +# https://github.com/marketplace/actions/pypi-publish + +name: Publish package and docs + +on: + push: + branches: [ release ] + +jobs: + build-and-test: + uses: ./.github/workflows/build-and-test.yml + + create-tag: + name: Create Git Tag + needs: build-and-test + runs-on: ubuntu-latest + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Create Git Tag + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + VERSION: ${{ needs.build-and-test.outputs.version }} + run: | + git config --global user.name 'github-actions' + git config --global user.email 'github-actions@github.com' + git tag "v${VERSION}" + git push origin "v${VERSION}" + + publish-to-pypi: + name: Publish to PyPI + needs: [build-and-test, create-tag] + runs-on: ubuntu-latest + environment: + name: pypi + url: https://pypi.org/p/paradigma + permissions: + id-token: write # mandatory for trusted publishing + + steps: + - name: Download all the dists + uses: actions/download-artifact@v4 + with: + name: build-artifacts + path: dist/ + - name: Publish distribution 📦 to PyPI + uses: pypa/gh-action-pypi-publish@release/v1 + + + github-release: + name: Sign distribution and create GitHub release + needs: [build-and-test, create-tag] + runs-on: ubuntu-latest + + permissions: + contents: write # mandatory for making GitHub Releases + id-token: write # mandatory for sigstore + + steps: + - name: Download all the dists + uses: actions/download-artifact@v4 + with: + name: build-artifacts + path: dist/ + + - name: Sign the dists with Sigstore + uses: sigstore/gh-action-sigstore-python@v2.1.1 + with: + inputs: >- + ./dist/*.tar.gz + ./dist/*.whl + + - name: Create GitHub Release + env: + GITHUB_TOKEN: ${{ github.token }} + VERSION: ${{ needs.build-and-test.outputs.version }} + run: >- + gh release create + "v${VERSION}" + --repo '${{ github.repository }}' + --notes "" + + - name: Upload artifact signatures to GitHub Release + env: + GITHUB_TOKEN: ${{ github.token }} + VERSION: ${{ needs.build-and-test.outputs.version }} + # Upload to GitHub Release using the `gh` CLI. + # `dist/` contains the built packages, and the + # sigstore-produced signatures and certificates. + run: >- + gh release upload + "v${VERSION}" dist/** + --repo '${{ github.repository }}' + + + publish-docs: + name: Publish documentation + needs: build-and-test + runs-on: ubuntu-latest + permissions: + contents: write + steps: + - name: Download the documentation + uses: actions/download-artifact@v4 + with: + name: docs-html + path: docs/ + - name: Deploy + uses: peaceiris/actions-gh-pages@v3 + with: + github_token: ${{ secrets.GITHUB_TOKEN }} + publish_dir: docs/