Skip to content

chore: format

chore: format #70

Workflow file for this run

name: Tests
on:
push:
branches:
- main
paths:
- 'src/**'
pull_request:
branches:
- main
paths:
- 'src/**'
workflow_dispatch:
defaults:
run:
shell: bash
jobs:
test:
name: Tests
strategy:
fail-fast: false
matrix:
python-version: ['3.9', '3.10', '3.11', '3.12']
os: [ubuntu-latest, macos-latest, windows-latest]
runs-on: ${{ matrix.os }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup Python
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Install pipx
run: python -m pip install pipx
- name: Install poetry
run: pipx install poetry
- name: Setup a local virtual environment
run: |
poetry config virtualenvs.create true --local
poetry config virtualenvs.in-project true --local
- uses: actions/cache@v4
name: Define a cache for the venv based on the dependencies lock file
with:
key: ${{ matrix.os }}-${{ hashFiles('poetry.lock') }}
path: ./.venv
- name: Install the project dependencies
run: poetry install
- name: Run tests and generate coverage
run: |
poetry run coverage run -m pytest
poetry run coverage xml
- name: Build
run: poetry build
- name: Get version
id: version
run: echo "version=$(poetry run python -c 'import pyanilist; print(pyanilist.__version__)')" >> $GITHUB_OUTPUT
- uses: actions/upload-artifact@v4
with:
name: pyanilist-${{ steps.version.outputs.version }}-${{ matrix.python-version }}-${{ matrix.os }}
path: "dist/*"
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v4
with:
env_vars: OS,PYTHON
token: ${{ secrets.CODECOV_TOKEN }}
verbose: true