Publish #42
Workflow file for this run
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: Publish | |
on: workflow_dispatch | |
env: | |
POETRY_VERSION: 1.7.1 | |
CONVCO_VERSION: v0.4.2 | |
GITCLIFF_VERSION: 1.3.0 | |
CHANGELOG_FILE: CHANGELOG.md | |
FULL_CHANGELOG_FILE: FULL_CHANGELOG.md | |
# Do not allow more than one publish job to run at a time | |
concurrency: | |
group: "publish" | |
cancel-in-progress: false | |
jobs: | |
publish-python: | |
runs-on: ubuntu-22.04 # convco needs GLIBC_2.32 which is not in 20.04 | |
environment: publish | |
# IMPORTANT: trusted publishing requires permission: id-token: write! Without it, the trusted publishing will not work! | |
# If the permission is the only one that is set, all other permissions are automatically set to none, which may cause permissions issues within the job. | |
permissions: write-all | |
outputs: | |
new_version: ${{ steps.set-vars.outputs.new_version }} | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- name: Install poetry | |
run: curl -sSL https://install.python-poetry.org | python3 - --version ${{ env.POETRY_VERSION }} | |
- name: Install convco | |
run: | | |
curl -sSfL "https://github.com/convco/convco/releases/download/${{ env.CONVCO_VERSION }}/convco-ubuntu.zip" | zcat > /usr/local/bin/convco | |
chmod +x /usr/local/bin/convco | |
- name: Set variables | |
id: set-vars | |
run: | | |
base_version_command=" | |
convco | |
version | |
--prefix=v | |
" | |
old_version=$($base_version_command) | |
new_version=$($base_version_command --bump) | |
new_tag=v"$new_version" | |
echo "OLD_VERSION=$old_version" >> $GITHUB_ENV | |
echo "NEW_VERSION=$new_version" >> $GITHUB_ENV | |
echo "new_version=$new_version" >> $GITHUB_OUTPUT | |
echo "NEW_MAJOR_VERSION=$(echo $new_version | cut -d'.' -f1)" >> $GITHUB_ENV | |
echo "NEW_TAG=$new_tag" >> $GITHUB_ENV | |
echo "old version: $old_version" | |
echo "new version: $new_version" | |
echo "new tag: $new_tag" | |
- name: Release | |
# Only run if the version has changed. | |
# Only start publishing automatically when the major version is 1 or higher. | |
if: ${{ env.OLD_VERSION != env.NEW_VERSION && env.NEW_MAJOR_VERSION >= 1 }} | |
env: | |
GH_TOKEN: ${{ github.token }} | |
run: | | |
######################################## | |
# Generate changelogs | |
######################################## | |
git_cliff_command="npx git-cliff@${{ env.GITCLIFF_VERSION }} --tag=${{ env.NEW_TAG }}" | |
$git_cliff_command --unreleased > ${{ env.CHANGELOG_FILE }} | |
$git_cliff_command > ${{ env.FULL_CHANGELOG_FILE }} | |
######################################## | |
# Create GitHub Release | |
######################################## | |
gh release create \ | |
${{ env.NEW_TAG }} \ | |
--title ${{ env.NEW_TAG }} \ | |
--notes-file ${{ env.CHANGELOG_FILE }} \ | |
${{ env.FULL_CHANGELOG_FILE }} | |
######################################## | |
# Build package | |
######################################## | |
poetry version ${{ env.NEW_VERSION }} | |
poetry build | |
- name: Publish | |
uses: pypa/gh-action-pypi-publish@release/v1 | |
build-docs: | |
runs-on: ubuntu-22.04 | |
needs: publish-python | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: 3.11 | |
- name: Install poetry | |
run: curl -sSL https://install.python-poetry.org | python3 - --version ${{ env.POETRY_VERSION }} | |
- uses: actions/cache@v3 | |
with: | |
path: .venv/ | |
key: ${{ runner.os }}-python-3.11-poetry-${{ hashFiles('pyproject.toml') }} | |
- name: Install dependencies | |
if: steps.cache.outputs.cache-hit != 'true' | |
run: | | |
poetry config --local virtualenvs.in-project true | |
poetry install -E all | |
- name: Build docs | |
run: | | |
poetry version ${{ needs.publish-python.outputs.new_version }} | |
poetry run sphinx-apidoc -o docs/source/ edvart | |
poetry run make -C docs html | |
- name: Upload HTML | |
uses: actions/upload-artifact@v3 | |
with: | |
name: html | |
path: docs/build/html | |
retention-days: 1 | |
deploy-pages: | |
environment: | |
name: github-pages | |
url: ${{ steps.deployment.outputs.page_url }} | |
permissions: | |
pages: write # to deploy to Pages | |
id-token: write # to verify the deployment originates from an appropriate source | |
needs: | |
- build-docs | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Setup Pages | |
uses: actions/configure-pages@v3 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: html | |
path: docs/build/html | |
- name: Upload artifact | |
uses: actions/upload-pages-artifact@v2 | |
with: | |
path: docs/build/html | |
- name: Deploy to GitHub Pages | |
id: deployment | |
uses: actions/deploy-pages@v2 |