-
Notifications
You must be signed in to change notification settings - Fork 0
93 lines (76 loc) · 2.77 KB
/
python-publish.yml
File metadata and controls
93 lines (76 loc) · 2.77 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
# This workflow publishes the package to TestPyPI when a version tag is pushed.
# Tag format must be: version-X.Y.Z
# This workflow uses actions that are not certified by GitHub.
# They are provided by a third-party and are governed by
# separate terms of service, privacy policy, and support
# documentation.
name: Publish Python package (TestPyPI)
on:
push:
tags:
- 'version-*'
permissions:
contents: read
jobs:
release-build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
- uses: actions/setup-python@v6
with:
python-version: "3.12"
- name: Validate tag matches project version
run: |
tag="${GITHUB_REF_NAME}"
if [[ ! "$tag" =~ ^version-[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
echo "Tag '$tag' does not match required pattern version-X.Y.Z"
exit 1
fi
project_version=$(python - <<'PY'
import pathlib, re
content = pathlib.Path('pyproject.toml').read_text(encoding='utf-8')
m = re.search(r'^version\s*=\s*"([^"]+)"', content, flags=re.MULTILINE)
if not m:
raise SystemExit('Could not find project.version in pyproject.toml')
print(m.group(1))
PY
)
tag_version="${tag#version-}"
if [[ "$tag_version" != "$project_version" ]]; then
echo "Tag version '$tag_version' does not match pyproject version '$project_version'"
exit 1
fi
echo "Tag and project version are consistent: $project_version"
- name: Build release distributions
run: |
# NOTE: put your own distribution build steps here.
python -m pip install build
python -m build
- name: Upload distributions
uses: actions/upload-artifact@v7
with:
name: release-dists
path: dist/
testpypi-publish:
runs-on: ubuntu-latest
needs:
- release-build
permissions:
# IMPORTANT: this permission is mandatory for trusted publishing
id-token: write
# Dedicated environments with protections for publishing are strongly recommended.
# For more information, see: https://docs.github.com/en/actions/deployment/targeting-different-environments/using-environments-for-deployment#deployment-protection-rules
environment:
name: testpypi
url: https://test.pypi.org/project/fastmolwidget/
steps:
- name: Retrieve release distributions
uses: actions/download-artifact@v8
with:
name: release-dists
path: dist/
- name: Publish release distributions to TestPyPI
uses: pypa/gh-action-pypi-publish@release/v1
with:
packages-dir: dist/
repository-url: https://test.pypi.org/legacy/