-
-
Notifications
You must be signed in to change notification settings - Fork 60
223 lines (194 loc) · 6.71 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
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
---
name: Wheel creation
# Change this to whatever you want
on:
push:
tags:
- 'v*'
workflow_dispatch:
inputs:
release:
description: 'Release the wheels?'
type: boolean
required: false
default: false
concurrency:
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
cancel-in-progress: true
jobs:
# 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
build_wheels:
name: Wheel building for cp${{ matrix.python[0] }}-${{ matrix.platform_id }}-${{ matrix.manylinux_image }}
runs-on: ${{ matrix.os }}
strategy:
# Ensure that a wheel builder finishes even if another fails
fail-fast: false
matrix:
include:
# Window 64 bit
#- os: windows-latest
# python: ["310", "3.10"]
# platform_id: win_amd64
# Linux 64 bit manylinux2014
- os: ubuntu-latest
python: ["39", "3.9"]
platform_id: manylinux_x86_64
manylinux_image: manylinux2014
- os: ubuntu-latest
python: ["310", "3.10"]
platform_id: manylinux_x86_64
manylinux_image: manylinux2014
- os: ubuntu-latest
python: ["311", "3.11"]
platform_id: manylinux_x86_64
manylinux_image: manylinux2014
- os: ubuntu-latest
python: ["312", "3.12"]
platform_id: manylinux_x86_64
manylinux_image: manylinux2014
# MacOS x86_64
- os: macos-12
python: ["39", "3.9"]
platform_id: macosx_x86_64
- os: macos-12
python: ["310", "3.10"]
platform_id: macosx_x86_64
- os: macos-12
python: ["311", "3.11"]
platform_id: macosx_x86_64
- os: macos-12
python: ["312", "3.12"]
platform_id: macosx_x86_64
# MacOS arm64
- os: macos-14
python: ["39", "3.9"]
platform_id: macosx_arm64
- os: macos-14
python: ["310", "3.10"]
platform_id: macosx_arm64
- os: macos-14
python: ["311", "3.11"]
platform_id: macosx_arm64
- os: macos-14
python: ["312", "3.12"]
platform_id: macosx_arm64
steps:
- name: Checkout sisl
uses: actions/checkout@v4
- name: Ensure fortran
uses: fortran-lang/setup-fortran@v1
with:
compiler: gcc
version: 11
- name: Print-out commit information
run: |
echo "branch: ${{ github.event.inputs.branch }}"
echo "hash: ${{ github.sha }}"
echo "python-version: ${{ matrix.python[0] }} - ${{ matrix.python[1] }}"
- name: Build and test wheels
env:
CIBW_BUILD: cp${{ matrix.python[0] }}-${{ matrix.platform_id }}
CIBW_MANYLINUX_X86_64_IMAGE: ${{ matrix.manylinux_image }}
CIBW_MANYLINUX_I686_IMAGE: ${{ matrix.manylinux_image }}
shell: bash -el {0}
run: |
bash -e tools/build_tools/build_wheels.sh
# Upload the wheel to the action's artifact.
- name: Store artifacts
uses: actions/upload-artifact@v4
with:
name: artifact-cp${{ matrix.python[0] }}-${{ matrix.platform_id }}
path: ./wheelhouse/*.whl
# Build the source distribution as well
build_sdist:
name: Build source distribution
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Build sdist
run: |
pipx run build --sdist
- uses: actions/upload-artifact@v4
with:
path: dist/*.tar.gz
# Upload to testpypi
upload_testpypi:
needs: [build_sdist, build_wheels]
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags')
name: Publish package to TestPyPI
runs-on: ubuntu-latest
steps:
- uses: actions/download-artifact@v4
with:
merge-multiple: True
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-13, macos-14]
steps:
- name: Python installation
uses: actions/setup-python@v5
with:
python-version: "3.9"
- name: Wait for testpypi to catch up
run: |
sleep 20
version=${GITHUB_REF#refs/*/v}
echo "SISL_VERSION=${version#refs/*/}" >> $GITHUB_ENV
ls -lh
- name: Install sisl + dependencies (oldest numpy, not ARM)
if: matrix.os != 'macos-14'
run: |
python -m pip install -v \
--progress-bar=off \
--index-url https://test.pypi.org/simple/ \
--extra-index-url https://pypi.org/simple/ \
"sisl[test,viz]==${{ env.SISL_VERSION }}" \
"numpy==1.21.*" "scipy==1.6.*" "xarray==0.21.*"
- name: Install sisl + dependencies (arm)
if: matrix.os == 'macos-14'
run: |
python -m pip install -v \
--progress-bar=off \
--index-url https://test.pypi.org/simple/ \
--extra-index-url https://pypi.org/simple/ \
"sisl[test,viz]==${{ env.SISL_VERSION }}"
- name: sisl debug info
run: |
python -c 'from sisl._debug_info import * ; print_debug_info()'
- 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@v4
with:
merge-multiple: True
path: dist
- uses: pypa/[email protected]
with:
user: __token__
password: ${{ secrets.PYPI_TOKEN }}