-
-
Notifications
You must be signed in to change notification settings - Fork 1
77 lines (73 loc) Β· 2.25 KB
/
tests.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
---
name: Testing
# yamllint disable-line rule:truthy
on:
push:
pull_request:
workflow_dispatch:
env:
DEFAULT_PYTHON: "3.11"
jobs:
pytest:
name: Python ${{ matrix.python }}
runs-on: ubuntu-latest
strategy:
matrix:
python: ["3.11", "3.12", "3.13"]
steps:
- name: β€΅οΈ Check out code from GitHub
uses: actions/checkout@v4.2.2
- name: π Set up Poetry
run: pipx install poetry
- name: π Set up Python ${{ matrix.python }}
id: python
uses: actions/setup-python@v5.3.0
with:
python-version: ${{ matrix.python }}
cache: "poetry"
- name: π Install workflow dependencies
run: |
poetry config virtualenvs.create true
poetry config virtualenvs.in-project true
- name: π Install dependencies
run: poetry install --no-interaction
- name: π Run pytest
run: poetry run pytest --cov src tests
- name: β¬οΈ Upload coverage artifact
uses: actions/upload-artifact@v4.6.0
with:
name: coverage-${{ matrix.python }}
include-hidden-files: true
path: .coverage
coverage:
runs-on: ubuntu-latest
needs: pytest
steps:
- name: β€΅οΈ Check out code from GitHub
uses: actions/checkout@v4.2.2
with:
fetch-depth: 0
- name: β¬οΈ Download coverage data
uses: actions/download-artifact@v4.1.8
- name: π Set up Poetry
run: pipx install poetry
- name: π Set up Python ${{ env.DEFAULT_PYTHON }}
id: python
uses: actions/setup-python@v5.3.0
with:
python-version: ${{ env.DEFAULT_PYTHON }}
cache: "poetry"
- name: π Install workflow dependencies
run: |
poetry config virtualenvs.create true
poetry config virtualenvs.in-project true
- name: π Install dependencies
run: poetry install --no-interaction
- name: π Process coverage results
run: |
poetry run coverage combine coverage*/.coverage*
poetry run coverage xml -i
- name: π Upload coverage report
uses: codecov/codecov-action@v5.1.2
with:
token: ${{ secrets.CODECOV_TOKEN }}