rnsh/.github/workflows/python-publish.yml
2023-02-11 23:26:30 -06:00

74 lines
1.9 KiB
YAML

# This workflow will upload a Python Package using Twine when a release is created
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-python#publishing-to-package-registries
# This workflow uses actions that are not certified by GitHub.
# They are provided by a third-party and are governed by
# separate terms of service, privacy policy, and support
# documentation.
name: Publish
on:
release:
types: [published]
permissions:
contents: read
jobs:
deploy:
runs-on: [self-hosted, linux]
steps:
- uses: actions/checkout@v2
with:
fetch-depth: 1
- name: Set up Python 3.9
uses: actions/setup-python@v4
with:
python-version: 3.9
- name: Install Poetry Action
uses: snok/install-poetry@v1.3.3
- name: Cache Poetry virtualenv
uses: actions/cache@v3
id: cache
with:
path: ~/.virtualenvs
key: poetry-${{ hashFiles('**/poetry.lock') }}
restore-keys: |
poetry-${{ hashFiles('**/poetry.lock') }}
- name: Install Dependencies
run: poetry install
if: steps.cache.outputs.cache-hit != 'true'
- name: Test with pytest
run: poetry run pytest -m "not skip_ci" tests
- name: Build package
run: poetry build
- name: Upload a Build Artifact
uses: actions/upload-artifact@v3.1.2
with:
# Artifact name
name: "pip package"
# A file, directory or wildcard pattern that describes what to upload
path: "dist/*"
# The desired behavior if no files are found using the provided path.
if-no-files-found: error
- name: Publish to PyPI
run: poetry publish --build --username __token__ --password ${{ secrets.PYPI_API_TOKEN }}