-
-
Notifications
You must be signed in to change notification settings - Fork 60
197 lines (170 loc) · 5.86 KB
/
wheels.yaml
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
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
---
name: wheel creation
# Change this to whatever you want
on:
push:
tags:
- 'v*'
workflow_dispatch:
inputs:
branch:
description: 'Which branch to build wheels for'
required: false
default: 'main'
concurrency:
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
cancel-in-progress: true
jobs:
# Build all the wheels with pypa/cibuildwheels
build_wheels_linux:
name: Linux wheel cp${{ matrix.python }}-${{ matrix.platform_id }}-${{ matrix.manylinux_image }}
runs-on: ${{ matrix.os }}
# cibuildwheels already manages multiple python versions automatically
# by just detecting the os. However, it does everything in the same job
# and therefore in a serial manner. We build a matrix of operating systems
# and python versions so that builds are ran in parallel.
# The job matrix is basically copied from https://github.com/scikit-learn/scikit-learn/blob/main/.github/workflows/wheels.yml
strategy:
# If one of the jobs fails, continue with the others.
fail-fast: false
matrix:
os: [ubuntu-latest]
platform_id: [manylinux_x86_64]
manylinux_image: [manylinux2010, manylinux2014]
python: [38, 39, 310, 311]
exclude:
- python: 310
manylinux_image: manylinux2010
- python: 311
manylinux_image: manylinux2010
steps:
- uses: actions/checkout@v3
with:
submodules: false
# Setup the fortran compiler. This is aware of the operating system.
- uses: awvwgk/setup-fortran@main
id: setup-fortran
with:
compiler: gcc
version: 11
# We use the cibuildwheel action to take care of everything
- name: Build wheels
uses: pypa/[email protected]
env:
CIBW_BUILD: cp${{ matrix.python }}-${{ matrix.platform_id }}
# The rest of options are specified at pyproject.toml
# Upload the wheel to the action's articfact.
- uses: actions/upload-artifact@v3
with:
path: ./wheelhouse/*.whl
build_wheels_macos:
name: MacOS wheel cp${{ matrix.python }}-${{ matrix.platform_id }}
runs-on: ${{ matrix.os }}
strategy:
# If one of the jobs fails, continue with the others.
fail-fast: false
matrix:
os: [macos-latest]
platform_id: [macosx_x86_64, macosx_arm64]
python: [38, 39, 310, 311]
include:
- platform_id: macosx_arm64
env:
PYTHON_CROSSENV: 1
MACOSX_DEPLOYMENT_TARGET: 12.0
steps:
- uses: actions/checkout@v3
with:
submodules: false
# Setup the fortran compiler. This is aware of the operating system.
- uses: awvwgk/setup-fortran@main
id: setup-fortran
with:
compiler: gcc
version: 11
# We use the cibuildwheel action to take care of everything
- name: Build wheels
uses: pypa/[email protected]
env:
CIBW_BUILD: cp${{ matrix.python }}-${{ matrix.platform_id }}
CIBW_TEST_SKIP: "*-macosx_arm64 *-macosx_universal2:arm64"
# The rest of options are specified at pyproject.toml
# Upload the wheel to the action's articfact.
- uses: actions/upload-artifact@v3
with:
path: ./wheelhouse/*.whl
# Build the source distribution as well
build_sdist:
name: Build source distribution
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
submodules: false
- name: Build sdist
run: pipx run build --sdist
- uses: actions/upload-artifact@v3
with:
path: dist/*.tar.gz
# Upload to testpypi
upload_testpypi:
needs: [build_sdist, build_wheels_linux, build_wheels_macos]
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags')
name: Publish package to TestPyPI
runs-on: ubuntu-latest
steps:
- uses: actions/download-artifact@v3
with:
name: artifact
path: dist
- uses: pypa/[email protected]
with:
user: __token__
password: ${{ secrets.TESTPYPI_TOKEN }}
repository_url: https://test.pypi.org/legacy/
# Check that the testpypi installation works
test_testpypi:
needs: [upload_testpypi]
name: Test installation from TestPyPi
runs-on: ${{ matrix.os }}
strategy:
# If one of the jobs fails, continue with the others.
fail-fast: false
matrix:
os: [ubuntu-latest, macos-latest]
steps:
- uses: actions/download-artifact@v3
with:
name: artifact
path: dist
- name: Python installation
uses: actions/setup-python@v4
with:
python-version: "3.8"
# We should also wait for index to update on remote server
- name: Install sisl + dependencies
run: |
sleep 10
version=${GITHUB_REF#refs/*/v}
version=${version#refs/*/}
python -m pip install --progress-bar=off --find-links dist --index-url https://test.pypi.org/simple/ --extra-index-url https://pypi.org/simple/ sisl[test]==${version}
- name: Test the installation
run: |
pytest --pyargs sisl
# Upload to PyPI on every tag
upload_pypi:
needs: [test_testpypi]
name: Publish package to Pypi
runs-on: ubuntu-latest
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags')
# alternatively, to publish when a GitHub Release is created, use the following rule:
# if: github.event_name == 'release' && github.event.action == 'published'
steps:
- uses: actions/download-artifact@v3
with:
name: artifact
path: dist
- uses: pypa/[email protected]
with:
user: __token__
password: ${{ secrets.PYPI_TOKEN }}