-
Notifications
You must be signed in to change notification settings - Fork 175
65 lines (55 loc) · 1.66 KB
/
testing.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
name: Testing Pipeline
on:
push:
branches: [master]
pull_request:
types: [opened, synchronize, reopened]
jobs:
unit_tests:
runs-on: ubuntu-latest
strategy:
matrix:
python-version:
- "3.7"
- "3.8"
- "3.9"
- "3.10"
- "3.11"
- "3.12"
steps:
- name: Pull package data
uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Setup up uv
run: curl -LsSf https://astral.sh/uv/0.4.5/install.sh | sh
- name: Install dependencies
run: uv sync --all-extras --dev
- name: Run code linting
run: uv run ruff check tenable --exit-zero
- name: Run unit tests
run: uv run pytest --vcr-record=none tests --cov-report xml:cov/coverage.xml
- name: Save Coverage Report
uses: actions/upload-artifact@v4
with:
name: coverage_report_${{ matrix.python-version }}
path: cov
retention-days: 1
security_tests:
runs-on: ubuntu-latest
steps:
- name: Pull package data
uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: "3.8"
- name: Setup up uv
run: curl -LsSf https://astral.sh/uv/0.4.5/install.sh | sh
- name: Run pip-audit
run: |
uv export --format requirements-txt | uv tool run pip-audit
- name: Run Bandit code auditor
run: uv tool run --with "bandit[toml,baseline,sarif]" bandit -c pyproject.toml -r . -ll