slice
is now generic
#432
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: main | |
on: [push, pull_request] | |
jobs: | |
lint: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Install Hatch | |
run: pipx install hatch | |
- name: Set up python 3.9 | |
uses: actions/setup-python@v5 | |
with: | |
python-version: "3.9" | |
cache: "pip" | |
cache-dependency-path: "pyproject.toml" | |
- name: Check formatting | |
run: hatch run ruff-format --check | |
- name: Check docstrings with darglint | |
run: hatch run darglint | |
- name: Type check with mypy | |
run: hatch run mypy | |
- name: Lint with ruff | |
run: hatch run ruff | |
test: | |
runs-on: ${{ matrix.os }}-latest | |
strategy: | |
matrix: | |
os: [ubuntu, macos, windows] | |
python-version: | |
- "3.9" | |
- "3.10" | |
- "3.11" | |
- "3.12" | |
- "3.13" | |
- "pypy3.9" | |
- "pypy3.10" | |
fail-fast: false | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Install Hatch | |
run: pipx install hatch | |
- name: Set up python ${{ matrix.python-version }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
allow-prereleases: true | |
cache: "pip" | |
cache-dependency-path: "pyproject.toml" | |
- name: Test with pytest | |
env: | |
COVERAGE_FILE: .coverage.${{ matrix.os }}.${{ matrix.python-version }} | |
run: hatch run pytest-ci ${{ matrix.python-version }} | |
- name: Upload coverage data | |
uses: actions/upload-artifact@v4 | |
with: | |
name: coverage-data-${{ matrix.os }}-${{ matrix.python-version }} | |
path: .coverage.${{ matrix.os }}.${{ matrix.python-version }} | |
include-hidden-files: true | |
coverage: | |
runs-on: ubuntu-latest | |
needs: test | |
outputs: | |
percentage: ${{ steps.percentage.outputs.percentage }} | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Install Coverage.py | |
run: pipx install coverage[toml] | |
- name: Download coverage data | |
uses: actions/download-artifact@v4 | |
with: | |
pattern: coverage-data-* | |
merge-multiple: true | |
- name: Combine data | |
run: coverage combine | |
- name: Output coverage percentage | |
id: percentage | |
run: | | |
coverage json | |
echo "percentage=$(jq '.totals.percent_covered_display' coverage.json)" >> $GITHUB_OUTPUT | |
- name: Save coverage report | |
run: coverage report --format=markdown >> $GITHUB_STEP_SUMMARY | |
- name: Ensure 100% coverage | |
run: coverage report --fail-under=100 | |
coverage-badge: | |
runs-on: ubuntu-latest | |
needs: coverage | |
if: github.event_name == 'push' && github.ref_name == 'main' | |
permissions: | |
contents: write | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
ref: "coverage-badge" | |
- name: Calculate badge color | |
id: color | |
run: | | |
echo "color=$(python3 -Ic 'print( | |
min( | |
(percentage, color) | |
for percentage, color in [ | |
(100, "brightgreen"), | |
(90, "green"), | |
(70, "yellowgreen"), | |
(50, "yellow"), | |
(30, "orange"), | |
(0, "red"), | |
] | |
if percentage >= int(${{ needs.coverage.outputs.percentage }}) | |
)[1] | |
)')" >> $GITHUB_OUTPUT | |
- name: Update JSON file | |
run: | | |
jq -n \ | |
--argjson schemaVersion 1 \ | |
--arg label coverage \ | |
--arg message ${{ needs.coverage.outputs.percentage }}% \ | |
--arg color ${{ steps.color.outputs.color }} \ | |
'$ARGS.named' > coverage-badge.json | |
- name: Create commit | |
run: | | |
git config user.name 'github-actions[bot]' | |
git config user.email '41898282+github-actions[bot]@users.noreply.github.com' | |
git commit -am "Update coverage" && git push || true | |
build: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Install Hatch | |
run: pipx install hatch | |
- name: Build project | |
run: hatch build | |
- name: Upload artifacts | |
uses: actions/upload-artifact@v4 | |
with: | |
name: artifacts | |
path: dist/* | |
if-no-files-found: error | |
pypi-publish: | |
runs-on: ubuntu-latest | |
needs: | |
- lint | |
- test | |
- coverage | |
- build | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags') | |
environment: pypi-publish | |
permissions: | |
id-token: write | |
steps: | |
- name: Download artifacts | |
uses: actions/download-artifact@v4 | |
with: | |
name: artifacts | |
path: dist | |
- name: Publish to PyPI | |
uses: pypa/gh-action-pypi-publish@release/v1 | |
lint-spec-parser: | |
runs-on: ubuntu-latest | |
defaults: | |
run: | |
working-directory: spec_parser | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Install Poetry | |
run: pipx install poetry | |
- name: Set up python 3.9 | |
uses: actions/setup-python@v5 | |
with: | |
python-version: "3.9" | |
cache: "poetry" | |
cache-dependency-path: "spec_parser/poetry.lock" | |
- name: Install dependencies | |
run: poetry install --sync | |
- name: Check formatting | |
run: poetry run poe ruff-format --check | |
- name: Type check with mypy | |
run: poetry run poe mypy | |
- name: Lint with ruff | |
run: poetry run poe ruff | |
dummy-required-job: | |
runs-on: ubuntu-latest | |
needs: | |
- lint | |
- test | |
- coverage | |
- build | |
- lint-spec-parser | |
if: always() | |
steps: | |
- run: exit 1 | |
if: ${{ contains( needs.*.result, 'failure' ) || contains( needs.*.result, 'cancelled' ) }} |