-
Notifications
You must be signed in to change notification settings - Fork 0
166 lines (166 loc) · 4.67 KB
/
ci.yml
File metadata and controls
166 lines (166 loc) · 4.67 KB
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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
---
name: CI Build
on:
push:
branches: [main]
pull_request:
branches: [main]
jobs:
sca:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: 'Set up Python 3.11'
uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Install dependencies
run: |
pip install --upgrade pip
pip install .[dev]
- name: Check headers
run: isort --check-only **/*.py
- name: Check code style
run: black --check **/*.py
- name: Lint source code
run: pylint src/**/*.py
- name: Type check source code
run: mypy src/**/*.py
- name: Perform security checks
run: bandit -r src
version:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
ref: "${{ github.event.pull_request.head.sha }}"
fetch-depth: 0
- name: 'Set up Python 3.11'
uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Setup gitconfig
run: |
git config user.name 'autonomous-bot'
git config user.email 'an.autonomous.bot@gmail.com'
- name: Install dependencies
run: |
pip install --upgrade pip
pip install .[build]
- name: Bump version
run: |
version info
if [ "${GITHUB_REF##*/}" == "main" ]; then
version bump --commit --tag
version push --password "${{ secrets.GITHUB_TOKEN }}"
else
version bump
fi
version info --filepaths | tar -cvzf versioning.tar.gz -T -
- name: Store versioned files
uses: actions/upload-artifact@v4
with:
name: "versioning-${{ github.run_number }}"
path: versioning.tar.gz
# - name: Cache version changes
# id: versioned-files
# uses: actions/cache@v3
# with:
# key: "${{
# runner.os
# }}-versioning-${{
# hashFiles('versioning.tar.gz')
# }}"
# path: versioning.tar.gz
build:
runs-on: ubuntu-latest
needs: [version, sca]
steps:
- uses: actions/checkout@v4
- name: 'Set up Python 3.11'
uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Install dependencies
run: |
pip install --upgrade pip
pip install build==1.0.3
pip install .
- name: Download versioned files
uses: actions/download-artifact@v4
with:
name: "versioning-${{ github.run_number }}"
- name: Apply versioning changes
run: tar -xzf versioning.tar.gz
- name: Perform build
run: python -m build
- name: Store versioned files
uses: actions/upload-artifact@v4
with:
name: dist
path: dist
test:
runs-on: ubuntu-latest
needs: build
strategy:
matrix:
python-version:
- '3.6'
- '3.7'
- '3.8'
- '3.9'
- '3.10'
- '3.11'
- '3.12'
steps:
- uses: actions/checkout@v4
- name: Download versioned files
uses: actions/download-artifact@v4
with:
name: "versioning-${{ github.run_number }}"
- name: Install dependencies
run: tar -xzf versioning.tar.gz
- name: Download versioned files
uses: actions/download-artifact@v4
with:
name: dist
path: dist
- name: Install dependencies
run: |
pip install --upgrade pip
pip install .[dev]
pip install ./dist/*whl
- name: Perform tests
run: pytest --cov=compendium --cov-report=xml tests
publish:
if: github.ref == 'refs/heads/main'
runs-on: ubuntu-latest
needs: ['build', 'test']
steps:
- uses: actions/checkout@v4
- name: Download versioned files
uses: actions/download-artifact@v4
with:
name: "versioning-${{ github.run_number }}"
- name: Install dependencies
run: tar -xzf versioning.tar.gz
- name: Download versioned files
uses: actions/download-artifact@v4
with:
name: dist
path: dist
- name: 'Set up Python 3.11'
uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Install dependencies
run: |
pip install --upgrade pip
pip install twine==4.0.0
- name: Perform publish
run: |
twine upload dist/* \
--non-interactive \
--repository pypi \
--username __token__ \
--password "${{ secrets.TWINE_PASSWORD }}"