name: 'API: Code Quality' on: push: branches: - 'master' - 'v5.*' pull_request: branches: - 'master' - 'v5.*' concurrency: group: ${{ github.workflow }}-${{ github.ref }} cancel-in-progress: true env: API_WORKING_DIR: ./api permissions: {} jobs: api-code-quality: runs-on: ubuntu-latest timeout-minutes: 30 permissions: contents: read strategy: matrix: python-version: - '3.12' defaults: run: working-directory: ./api steps: - name: Harden Runner uses: step-security/harden-runner@ab7a9404c0f3da075243ca237b5fac12c98deaa5 # v2.19.3 with: egress-policy: block allowed-endpoints: > github.com:443 pypi.org:443 files.pythonhosted.org:443 api.github.com:443 raw.githubusercontent.com:443 - name: Checkout repository uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: # zizmor: ignore[artipacked] persist-credentials: true # Required by tj-actions/changed-files to fetch PR branch - name: Check for API changes id: check-changes uses: tj-actions/changed-files@9426d40962ed5378910ee2e21d5f8c6fcbf2dd96 # v47.0.6 with: files: | api/** .github/workflows/api-code-quality.yml files_ignore: | api/docs/** api/README.md api/CHANGELOG.md api/AGENTS.md - name: Setup Python with uv if: steps.check-changes.outputs.any_changed == 'true' uses: ./.github/actions/setup-python-uv with: python-version: ${{ matrix.python-version }} working-directory: ./api - name: uv lock check if: steps.check-changes.outputs.any_changed == 'true' run: uv lock --check - name: Ruff lint if: steps.check-changes.outputs.any_changed == 'true' run: uv run ruff check . --exclude contrib - name: Ruff format if: steps.check-changes.outputs.any_changed == 'true' run: uv run ruff format --check . --exclude contrib - name: Pylint if: steps.check-changes.outputs.any_changed == 'true' run: uv run pylint --disable=W,C,R,E -j 0 -rn -sn src/