-
Notifications
You must be signed in to change notification settings - Fork 5
80 lines (63 loc) · 1.81 KB
/
pull-request.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
name: PR - Lint and Test
on:
push:
branches:
- "main"
pull_request:
branches:
- "main"
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: ["3.9", "3.10", "3.11", "3.12"]
steps:
- uses: actions/checkout@v4
- name: Install poetry
run: |
python -m pip install --upgrade pip
pipx install poetry
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
cache: "poetry"
- name: Install dependencies
run: |
poetry install
poetry run pip list
- name: Poetry check
run: |
poetry lock --check
- name: Lint with flake8
run: |
poetry run flake8 . --ignore=E501
- name: Lint with ruff
uses: chartboost/ruff-action@v1
- name: Checking format with black
run: |
poetry run black --check .
- name: Lint with pylint
run: |
poetry run pylint --disable=W,C,R,E -j 0 -rn -sn py_ocsf_models/
- name: Check types with mypy
run: |
poetry run mypy --strict py_ocsf_models/
- name: Bandit
run: |
poetry run bandit -q -lll -x './tests' -r .
- name: Safety
run: |
poetry run safety check --ignore 70612
- name: Vulture
run: |
poetry run vulture --min-confidence 100 .
- name: Test with pytest
run: |
poetry run pytest -n auto --cov=./py_ocsf_models --cov-report=xml tests
- name: Upload coverage reports to Codecov
uses: codecov/[email protected]
with:
token: ${{ secrets.CODECOV_TOKEN }}
slug: prowler-cloud/py-ocsf-models