Skip to content

Support docker secrets for sensitive data #274

Support docker secrets for sensitive data

Support docker secrets for sensitive data #274

name: Python tests
on:
push:
branches:
- '*'
pull_request:
types: [ opened, synchronize, reopened ]
branches:
- '*'
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: [ "3.12", "3.13" ]
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
cache: 'pip'
- name: Install Poetry
uses: snok/install-poetry@v1
with:
virtualenvs-in-project: true
- name: Load cached venv
id: cached-poetry-dependencies
uses: actions/cache@v4
with:
path: .venv
key: venv-${{ runner.os }}-${{ hashFiles('**/poetry.lock') }}
- name: Install dependencies
if: steps.cached-poetry-dependencies.outputs.cache-hit != 'true'
run: |
poetry install --no-interaction --no-root
- name: Install library
run: poetry install --no-interaction
- name: Run mypy
run: |
poetry run mypy
- name: Lint with Ruff
run: |
poetry run ruff check . --output-format=github
if: success() || failure()
- name: Run tests with coverage
run: |
poetry run pytest tests --cov --junit-xml=junit/test-results-${{ matrix.python-version }}.xml
if: success() || failure()
- name: Surface failing tests
uses: pmeier/pytest-results-action@main
with:
title: Test results (Python ${{ matrix.python-version }})
path: junit/test-results-${{ matrix.python-version }}.xml
# (Optional) Add a summary of the results at the top of the report
summary: true
# (Optional) Select which results should be included in the report.
# Follows the same syntax as `pytest -r`
display-options: fEX
# (Optional) Fail the workflow if no JUnit XML was found.
fail-on-empty: true
if: ${{ always() }}