Skip to content

feat: release automation on main (#40) #14

feat: release automation on main (#40)

feat: release automation on main (#40) #14

Workflow file for this run

name: Release
on:
push:
branches:
- main
jobs:
release:
environment: release
name: Release to PyPI
concurrency: release
permissions:
contents: write
id-token: write
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Set up Python
id: setup-python
uses: actions/setup-python@v4
with:
python-version: "3.9"
- name: Install Poetry
uses: snok/install-poetry@v1
with:
virtualenvs-create: true
virtualenvs-in-project: true
installer-parallel: true
- name: Load cached venv
id: cached-poetry-dependencies
uses: actions/cache@v3
with:
path: .venv
key: venv-release-${{ runner.os }}-${{ steps.setup-python.outputs.python-version }}-${{ hashFiles('**/poetry.lock') }}
- name: Install dependencies
if: steps.cached-poetry-dependencies.outputs.cache-hit != 'true'
run: poetry install --no-interaction --no-root
- name: Install project
run: poetry install --no-interaction
- name: Semantic release
run: |
poetry run semantic-release version
poetry run semantic-release publish
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: build
run: poetry install && poetry build
- name: Publish package distributions to PyPI
uses: pypa/gh-action-pypi-publish@release/v1