-
-
Notifications
You must be signed in to change notification settings - Fork 7
133 lines (115 loc) · 4.03 KB
/
python-publish.yml
File metadata and controls
133 lines (115 loc) · 4.03 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
name: Python package
on:
push:
branches:
- main
pull_request:
jobs:
lint:
runs-on: ubuntu-latest
permissions:
contents: read
strategy:
matrix:
python-version: ["3.10"]
steps:
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Install Poetry
uses: snok/install-poetry@v1
with:
version: 1.7.1
virtualenvs-create: true
virtualenvs-in-project: true
- name: Install dependencies
run: poetry install
- name: Lint checking
run: poetry run ruff check -v --output-format=github --exclude=poc .
- name: Type checking
run: poetry run mypy -v --exclude='^poc/' .
release:
needs: [lint]
if: github.event_name == 'push' && github.ref == 'refs/heads/main'
runs-on: ubuntu-latest
permissions:
id-token: write # IMPORTANT: this permission is mandatory for trusted publishing
contents: write
strategy:
matrix:
python-version: ["3.10"]
steps:
#----------------------------------------------
# Create GitHub App Token
#----------------------------------------------
- name: Create GitHub App Token
uses: actions/create-github-app-token@v1
id: app-token
with:
app-id: ${{ vars.VERSION_BUMPER_APPID }}
private-key: ${{ secrets.VERSION_BUMPER_SECRET }}
#----------------------------------------------
# Checkout Code and Setup Python
#----------------------------------------------
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0 # pulls all history and tags for Lerna to detect which packages changed
token: ${{ steps.app-token.outputs.token }}
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
#----------------------------------------------
# Install Poetry
#----------------------------------------------
- name: Install Poetry
uses: snok/install-poetry@v1
with:
version: 1.7.1
virtualenvs-create: true
virtualenvs-in-project: true
installer-parallel: true
#----------------------------------------------
# Install Dependencies & Build Package
#----------------------------------------------
- name: Install dependencies
run: poetry install
- name: Build package
run: poetry build
- name: List build artifacts
run: ls -la dist/
#----------------------------------------------
# Upload Coverage to Codecov
#----------------------------------------------
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v4
with:
verbose: true
env:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
#----------------------------------------------
# Python Semantic Release
#----------------------------------------------
- name: Python Semantic Release (Version)
id: release
uses: python-semantic-release/python-semantic-release@v9.8.5
with:
github_token: ${{ steps.app-token.outputs.token }}
#----------------------------------------------
# Publish to PyPI & GitHub Release
#----------------------------------------------
- name: Publish package distributions to PyPI
uses: pypa/gh-action-pypi-publish@release/v1
with:
packages-dir: dist/
verbose: true
print-hash: true
- name: Publish package to GitHub Release
uses: python-semantic-release/upload-to-gh-release@v9.8.5
if: steps.release.outputs.released == 'true'
with:
github_token: ${{ steps.app-token.outputs.token }}
tag: ${{ steps.release.outputs.tag }}