Skip to content

Merge pull request #162 from spraakbanken/161-formattinglogginghandle… #126

Merge pull request #162 from spraakbanken/161-formattinglogginghandle…

Merge pull request #162 from spraakbanken/161-formattinglogginghandle… #126

Workflow file for this run

name: test
on:
push:
branches:
- main
pull_request:
merge_group:
concurrency:
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
cancel-in-progress: true
permissions:
contents: read
env:
MINIMUM_PYTHON_VERSION: "3.10"
UV_VERSION: "0.4.18"
UV_CACHE_DIR: /tmp/.uv-cache
jobs:
coverage:
# This action runs tests for coverage collection and uploads them to codecov.io.
# This requires the secret `CODECOV_TOKEN` be set as secret on GitHub, both for
# Actions and Dependabot
name: "${{ matrix.os }} / ${{ matrix.python-version }} / coverage"
strategy:
max-parallel: 4
fail-fast: false
matrix:
os: [ubuntu]
python-version:
# remove the unused versions
- "3.10"
- "3.11"
- "3.12"
- "3.13"
runs-on: ${{ matrix.os }}-latest
env:
OS: ${{ matrix.os }}-latest
PYTHON: ${{ matrix.python-version }}
steps:
- uses: actions/checkout@v4
with:
submodules: true
- name: Set up uv
run: curl -LsSf https://astral.sh/uv/${{ env.UV_VERSION }}/install.sh | sh
- name: Set up Python ${{ matrix.python-version }}
id: setup-python
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Restore uv cache
uses: actions/cache@v4
with:
path: /tmp/.uv-cache
key: uv-${{ runner.os }}-${{ hashFiles('uv.lock') }}
restore-keys: |
uv-${{ runner.os }}-${{ hashFiles('uv.lock') }}
uv-${{ runner.os }}
- name: Load cached venv
id: cached-venv
uses: actions/cache@v4
with:
path: .venv
key: venv-${{ runner.os }}-${{ steps.setup-python.outputs.python-version }}-${{ hashFiles('**/pyproject.toml') }}-${{ hashFiles('**/uv.lock') }}
- name: Install dependencies
if: steps.cached-venv.outputs.cache-hit != 'true'
run: uv sync --all-extras --dev
- name: Run tests for coverage
run: make test-w-coverage cov_report=xml
- name: Minimize uv cache
run: uv cache prune --ci
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v4
with:
token: ${{ secrets.CODECOV_TOKEN }}
# directory: ./coverage
env_vars: OS,PYTHON
fail_ci_if_error: true
# files: ./coverage/coverage.xml
# flags: unittests
# name: codecov-umbrella
verbose: true
# doctests:
# # This action runs doctests for coverage collection and uploads them to codecov.io.
# # This requires the secret `CODECOV_TOKEN` be set as secret on GitHub, both for
# # Actions and Dependabot
# name: "${{ matrix.os }} / 3.10 / doctest"
# strategy:
# max-parallel: 4
# fail-fast: false
# matrix:
# os: [ubuntu]
# runs-on: ${{ matrix.os }}-latest
# env:
# OS: ${{ matrix.os }}-latest
# steps:
# - uses: actions/checkout@v4
# with:
# submodules: true
# - name: Set up uv
# run: curl -LsSf https://astral.sh/uv/${{ env.UV_VERSION }}/install.sh | sh
# - name: Set up Python ${{ env.MINIMUM_PYTHON_VERSION }}
# id: setup-python
# uses: actions/setup-python@v5
# with:
# python-version: ${{ env.MINIMUM_PYTHON_VERSION }}
# - name: Restore uv cache
# uses: actions/cache@v4
# with:
# path: /tmp/.uv-cache
# key: uv-${{ runner.os }}-${{ hashFiles('uv.lock') }}
# restore-keys: |
# uv-${{ runner.os }}-${{ hashFiles('uv.lock') }}
# uv-${{ runner.os }}
# - name: Load cached venv
# id: cached-venv
# uses: actions/cache@v4
# with:
# path: .venv
# key: venv-${{ runner.os }}-${{ steps.setup-python.outputs.python-version }}-${{ hashFiles('**/pyproject.toml') }}-${{ hashFiles('**/uv.lock') }}
# - name: Install dependencies
# if: steps.cached-venv.outputs.cache-hit != 'true'
# run: uv sync --all-extras --dev
# #----------------------------------------------
# # Run tests and upload coverage
# #----------------------------------------------
# - name: make doc-tests
# run: make doc-tests cov_report=xml
# - name: Minimize uv cache
# run: uv cache prune --ci
# - name: Upload coverage to Codecov
# uses: codecov/codecov-action@v4
# with:
# token: ${{ secrets.CODECOV_TOKEN }}
# # directory: ./coverage
# env_vars: OS,PYTHON,TESTTYPE
# fail_ci_if_error: true
# # files: ./coverage/coverage.xml
# # flags: unittests
# # name: codecov-umbrella
# verbose: true
# env:
# PYTHON: ${{ env.MINIMUM_PYTHON_VERSION }}
# TESTTYPE: doctest
minimal:
# This action chooses the oldest version of the dependencies permitted by Cargo.toml to ensure
# that this crate is compatible with the minimal version that this crate and its dependencies
# require. This will pickup issues where this create relies on functionality that was introduced
# later than the actual version specified (e.g., when we choose just a major version, but a
# method was added after this version).
#
runs-on: ubuntu-latest
name: ubuntu / 3.10 / minimal-versions
steps:
- uses: actions/checkout@v4
with:
submodules: true
- name: Set up uv
run: curl -LsSf https://astral.sh/uv/${{ env.UV_VERSION }}/install.sh | sh
- name: Set up Python ${{ env.MINIMUM_PYTHON_VERSION }}
id: setup-python
uses: actions/setup-python@v5
with:
python-version: ${{ env.MINIMUM_PYTHON_VERSION }}
- name: Restore uv cache
uses: actions/cache@v4
with:
path: /tmp/.uv-cache
key: uv-${{ runner.os }}-${{ hashFiles('uv.lock') }}
restore-keys: |
uv-${{ runner.os }}-${{ hashFiles('uv.lock') }}
uv-${{ runner.os }}
- name: install lowest direct dependencies
run: uv sync --resolution lowest-direct --all-extras --dev
- name: make test
run: make test
- name: Minimize uv cache
run: uv cache prune --ci
# https://github.com/marketplace/actions/alls-green#why used for branch protection checks
test-check:
if: always()
needs:
- coverage
# - doctests
- minimal
runs-on: ubuntu-latest
permissions: {}
steps:
- name: Decide whether the needed jobs succeeded or failed
uses: re-actors/alls-green@release/v1
with:
jobs: ${{ toJSON(needs) }}