Skip to content

Feature add pyflint code #40

Feature add pyflint code

Feature add pyflint code #40

Workflow file for this run

name: tests
on:
push:
branches:
pull_request:
branches:
jobs:
linting:
name: Linting
runs-on: ubuntu-latest
steps:
- uses: actions/[email protected]
- name: Set up Python 3.9
uses: actions/[email protected]
with:
python-version: 3.9
- name: Install system deps
shell: bash
run: |
pip install poetry
poetry config virtualenvs.in-project true
poetry install --no-root --only dev --only linters --sync
- name: Linting
shell: bash
run: poetry run pre-commit run --all-files
tests:
needs: linting
name: ${{ matrix.os }} / ${{ matrix.python-version }}
runs-on: ${{ matrix.os }}-latest
strategy:
matrix:
os: [Ubuntu, MacOS, Windows]
python-version: ['3.9', '3.10', '3.11', '3.12']
fail-fast: true
steps:
- uses: actions/[email protected]
- name: Set up Python ${{ matrix.python-version }}
uses: actions/[email protected]
with:
python-version: ${{ matrix.python-version }}
- name: Install system deps
shell: bash
run: |
pip install nox-poetry
pip install poetry
poetry config virtualenvs.in-project true
- name: Run mypy with nox
shell: bash
run: nox --force-color -s mypy-${{ matrix.python-version }}
- name: Run tests with nox
shell: bash
run: nox --force-color -s tests-${{ matrix.python-version }}
- name: Run securtity check
if: matrix.python-version == '3.12' && matrix.os == 'Ubuntu'
shell: bash
run: nox --force-color -s security
- name: Upload coverage data
uses: actions/upload-artifact@v4
with:
name: ${{ matrix.os }}-${{ matrix.python-version }}.coverage-data
path: ".coverage.*"
retention-days: 2
coverage:
needs: tests
runs-on: ubuntu-latest
steps:
- uses: actions/[email protected]
- name: Set up Python 3.9
uses: actions/[email protected]
with:
python-version: 3.9
- name: Install system deps
shell: bash
run: |
pip install nox-poetry
pip install poetry
poetry config virtualenvs.in-project true
- name: Download coverage data
uses: actions/download-artifact@v4
with:
pattern: "*.coverage-data"
merge-multiple: true
- name: Create coverage report
shell: bash
run: |
nox --force-color --session=coverage -- --fmt xml
- name: Upload coverage report
uses: codecov/[email protected]
with:
token: ${{ secrets.CODECOV_TOKEN }}