Skip to content

Integration/lsim

Integration/lsim #136

Workflow file for this run

name: Test
on:
push:
branches:
- main
paths:
- '**.py'
pull_request:
types:
- opened
- synchronize
paths:
- '**.py'
schedule:
# cron every week on monday
- cron: "0 0 * * 1"
jobs:
test:
name: test ${{ matrix.os }} / ${{ matrix.python-version }}
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest, macos-13, macos-latest, windows-latest]
python-version: ['3.9', '3.10', '3.11', '3.12', '3.13']
exclude:
# Python 3.9 is not available on macOS 14
- os: macos-13
python-version: '3.10'
- os: macos-13
python-version: '3.11'
- os: macos-13
python-version: '3.12'
- os: macos-13
python-version: '3.13'
- os: macos-latest
python-version: '3.9'
defaults:
run:
shell: bash
env:
OS: ${{ matrix.os }}
DEPS: yes
runs-on: ${{ matrix.os }}
steps:
- name: Dump GitHub context
env:
GITHUB_CONTEXT: ${{ toJson(github) }}
run: echo "$GITHUB_CONTEXT"
#----------------------------------------------
# ----- Checkout -----
#----------------------------------------------
- uses: actions/checkout@v4
#----------------------------------------------
# ----- install & configure uv -----
#----------------------------------------------
- name: Install uv
uses: astral-sh/setup-uv@v5
with:
python-version: ${{ matrix.python-version }}
#----------------------------------------------
# load cached venv if cache exists
#----------------------------------------------
- name: Load cached venv
id: cached-uv-dependencies
uses: actions/cache@v4
with:
path: .venv
key: venv-${{ runner.os }}-${{ matrix.python-version }}-${{ hashFiles('pyproject.toml') }}
#----------------------------------------------
# install dependencies if cache does not exist
#----------------------------------------------
- name: Install dependencies
if: steps.cached-uv-dependencies.outputs.cache-hit != 'true'
run: uv export --only-group=gh | uv pip install --requirements=-
#----------------------------------------------
# run test suite
#----------------------------------------------
- run: mkdir coverage
- name: Run tests
run: |
# source $VENV
make test-github
env:
COVERAGE_FILE: coverage/.coverage.${{ runner.os }}-py${{ matrix.python-version }}
CONTEXT: ${{ runner.os }}-py${{ matrix.python-version }}
- name: Store coverage files
uses: actions/upload-artifact@v4
with:
name: coverage-${{ runner.os }}-py${{ matrix.python-version }}
path: coverage
include-hidden-files: true
coverage-combine:
needs: [test]
runs-on: ubuntu-latest
defaults:
run:
shell: bash
steps:
- name: Dump GitHub context
env:
GITHUB_CONTEXT: ${{ toJson(github) }}
run: echo "$GITHUB_CONTEXT"
- uses: actions/checkout@v4
#----------------------------------------------
# ----- install & configure uv -----
#----------------------------------------------
- name: Install uv
uses: astral-sh/setup-uv@v5
with:
python-version: '3.9'
#----------------------------------------------
# load cached venv if cache exists
#----------------------------------------------
- name: Load cached venv
id: cached-uv-dependencies
uses: actions/cache@v4
with:
path: .venv
key: venv-Linux-3.9-${{ hashFiles('pyproject.toml') }}
#----------------------------------------------
- name: Get coverage files
uses: actions/download-artifact@v4
with:
pattern: coverage-*
path: coverage
merge-multiple: true
- run: ls -la coverage
- run: uv run coverage combine coverage
- run: uv run coverage report
- run: uv run coverage html --title "Coverage for ${{ github.sha }}"
- name: Store coverage HTML
uses: actions/upload-artifact@v4
with:
name: coverage-html
path: htmlcov
include-hidden-files: true