-
Notifications
You must be signed in to change notification settings - Fork 41
105 lines (86 loc) · 2.56 KB
/
lint_and_test.yml
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
name: Lint and test
on:
workflow_dispatch:
push:
jobs:
linting:
runs-on: ubuntu-latest
steps:
- name: Checkout 🛎️
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Pull docker image 🐳
run: docker pull riga/law:py38
- name: Lint 🔍
run: ./tests/docker.sh riga/law:py312-rc ./tests/linting.sh
typecheck:
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
python: ["38", "39", "310", "311", "312"]
name: typecheck (python ${{ matrix.python }})
steps:
- name: Checkout 🛎️
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Pull docker image 🐳
run: docker pull riga/law:py${{ matrix.python }}-rc
- name: Typecheck 📋
run: ./tests/docker.sh riga/law:py${{ matrix.python }}-rc ./tests/typecheck.sh
unittest:
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
python: ["38", "39", "310", "311", "312"]
name: unittest (python ${{ matrix.python }})
steps:
- name: Checkout 🛎️
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Pull docker image 🐳
run: docker pull riga/law:py${{ matrix.python }}-rc
- name: Test 🎢
run: ./tests/docker.sh riga/law:py${{ matrix.python }}-rc ./tests/unittest.sh
pypi:
runs-on: ubuntu-latest
steps:
- name: Checkout 🛎️
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Setup python 🐍
uses: actions/setup-python@v5
with:
python-version: 3.12
- name: Install dependencies ☕️
run: |
pip install -U pip setuptools
pip install -U twine build
- name: Check bundling 📦
run: python -m build
- name: Check setup 🚦
run: twine check "dist/law-*.tar.gz"
coverage:
runs-on: ubuntu-latest
steps:
- name: Checkout ⬇️
uses: actions/checkout@v4
with:
persist-credentials: false
submodules: recursive
- name: Pull docker image 🐳
run: docker pull riga/law:py312-rc
- name: Run coverage test 🎢
run: ./tests/docker.sh riga/law:py312-rc ./tests/coverage.sh
- name: Upload report 🔝
uses: codecov/codecov-action@v5
with:
token: ${{ secrets.CODECOV_TOKEN }}
files: ./coverage.xml
flags: unittests
fail_ci_if_error: false