-
-
Notifications
You must be signed in to change notification settings - Fork 249
222 lines (191 loc) · 7.88 KB
/
build-wheels.yml
File metadata and controls
222 lines (191 loc) · 7.88 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
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
name: Build wheels
# By default this action does not push to test or production PyPI. The wheels
# are available as an artifact that can be downloaded and tested locally.
on:
workflow_dispatch:
inputs:
dolfinx_ref:
description: "dolfinx git ref to checkout"
default: "main"
type: string
build_fenicsx_stack:
description: "Build wheels for whole FEniCSx stack"
default: false
type: boolean
basix_ref:
description: "basix git ref to checkout"
default: "main"
type: string
ufl_ref:
description: "ufl git ref to checkout"
default: "main"
type: string
ffcx_ref:
description: "ffcx git ref to checkout"
default: "main"
type: string
workflow_call:
inputs:
dolfinx_ref:
description: "dolfinx git ref to checkout"
default: "main"
type: string
build_fenicsx_stack:
description: "Build wheels for entire FEniCSx stack"
default: false
type: boolean
basix_ref:
description: "basix git ref to checkout"
default: "main"
type: string
ufl_ref:
description: "ufl git ref to checkout"
default: "main"
type: string
ffcx_ref:
description: "ffcx git ref to checkout"
default: "main"
type: string
jobs:
build_wheels:
name: Build wheels
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-latest, ubuntu-24.04-arm]
env:
CIBW_BUILD: cp312-manylinux_x86_64 cp312-manylinux_aarch64
CIBW_BUILD_VERBOSITY: 1
CIBW_ENVIRONMENT: PIP_EXTRA_INDEX_URL=file:///project/simple
CIBW_ARCHS_LINUX: native
CIBW_MANYLINUX_X86_64_IMAGE: quay.io/pypa/manylinux_2_34_x86_64:latest
CIBW_MANYLINUX_AARCH64_IMAGE: quay.io/pypa/manylinux_2_34_aarch64:latest
steps:
- uses: actions/setup-python@v6
- name: Install Python dependencies
run: python -m pip install cibuildwheel simple503 build
- name: Checkout UFL
if: ${{ github.event.inputs.build_fenicsx_stack == 'true' }}
uses: actions/checkout@v6
with:
repository: FEniCS/ufl
path: ufl
ref: ${{ github.event.inputs.ufl_ref }}
- name: Build UFL wheel
if: ${{ github.event.inputs.build_fenicsx_stack == 'true' }}
run: |
python -m build -o wheelhouse/ ufl/
- name: Checkout FFCx
if: ${{ github.event.inputs.build_fenicsx_stack == 'true' }}
uses: actions/checkout@v6
with:
repository: FEniCS/ffcx
path: ffcx
ref: ${{ github.event.inputs.ffcx_ref }}
- name: Build FFCx wheel
if: ${{ github.event.inputs.build_fenicsx_stack == 'true' }}
run: |
python -m build -o wheelhouse/ ffcx/
- name: Checkout Basix
if: ${{ github.event.inputs.build_fenicsx_stack == 'true' }}
uses: actions/checkout@v6
with:
repository: FEniCS/basix
path: basix
ref: ${{ github.event.inputs.basix_ref }}
- name: Build Basix wheel
if: ${{ github.event.inputs.build_fenicsx_stack == 'true' }}
working-directory: basix/
run: |
python -m cibuildwheel --output-dir ../wheelhouse/ .
- name: Make temporary simple503 repository
run: |
mkdir -p simple
cp wheelhouse/* simple/
python -m simple503 --base-url file:///project/simple simple/
- name: Checkout DOLFINx
uses: actions/checkout@v6
with:
path: dolfinx
ref: ${{ github.event.inputs.dolfinx_ref }}
# fenics-ffcx and fenics-basix are required by DOLFINx C++ build
# mpi4py and petsc4py are build_requirements of DOLFINx Python
- name: Build DOLFINx wheel
run: |
python -m cibuildwheel --output-dir wheelhouse/ dolfinx/python
env:
CIBW_BEFORE_BUILD_LINUX: >
dnf -y update &&
dnf install -y dnf-plugins-core &&
dnf install -y epel-release &&
/usr/bin/crb enable &&
dnf -y update &&
dnf -y install boost-devel boost-program-options git hdf5-mpich-devel make \
mpich-devel ninja-build openblas-devel pugixml-devel spdlog-devel &&
ln -s /usr/include/mpich-$(arch) /usr/lib64/mpich/include &&
git clone --branch v7.0.9 --single-branch https://gitlab.inria.fr/scotch/scotch.git &&
cmake -G Ninja -S scotch/ -B scotch-build-dir/ -DCMAKE_INSTALL_PREFIX=/usr/local \
-DBUILD_SHARED_LIBS=ON -DMPI_HOME=/usr/lib64/mpich &&
cmake --build scotch-build-dir/ &&
cmake --install scotch-build-dir/ &&
pip -v install 'fenics-basix==0.11.0.dev0' 'fenics-ffcx==0.11.0.dev0' &&
pip -v install mpi4py scikit-build-core[pyproject] nanobind &&
cmake -G Ninja -S dolfinx/cpp -B dolfinx-build-dir/ -DPython3_EXECUTABLE=$(which python) \
-DHDF5_ROOT=/usr/lib64/mpich -DMPI_HOME=/usr/lib64/mpich -DCMAKE_BUILD_TYPE=RelWithDebug &&
cmake --build dolfinx-build-dir/ &&
cmake --install dolfinx-build-dir/
CIBW_CONFIG_SETTINGS_LINUX: >
cmake.args="-DMPI_HOME=/usr/lib64/mpich;-DHDF5_ROOT=/usr/lib64/mpich"
wheel.py-api=cp312
cmake.build-type="RelWithDebug"
CIBW_BUILD_FRONTEND: "build; args: -nx"
CIBW_REPAIR_WHEEL_COMMAND_LINUX: >
export LD_LIBRARY_PATH=$(python -c "import site; print(site.getsitepackages()[0] + '/fenics_basix.libs')"):${LD_LIBRARY_PATH} &&
auditwheel repair --exclude libmpi.so.* -w {dest_dir} {wheel} &&
pipx run abi3audit --verbose --strict --report {wheel}
CIBW_TEST_REQUIRES: pytest-xdist
CIBW_TEST_EXTRAS: test
CIBW_TEST_COMMAND: >
. /etc/profile &&
module load mpi/mpich-$(arch) &&
python -m pytest -n auto \
-m "not adios2 and not petsc4py" {project}/dolfinx/python/test/unit &&
mpiexec -n 2 python -m pytest \
-m "not adios2 and not petsc4py" {project}/dolfinx/python/test/unit
- name: Update temporary simple503 repository
run: |
cp wheelhouse/* simple
python -m simple503 --base-url file:///shared simple
- name: Upload simple503-test artifact
uses: actions/upload-artifact@v7
with:
name: simple503-test-${{ matrix.os }}
path: simple/*
- name: Test in clean python image with pypi MPICH
run: >
cd dolfinx &&
sudo git clean -fdx && cd ../ &&
docker run -v $(pwd)/dolfinx:/dolfinx -v $(pwd)/simple:/shared \
--env PIP_EXTRA_INDEX_URL=file:///shared python:3.13 \
/bin/bash -l -c "pip install mpich fenics-dolfinx[test] && mpiexec -n 2 python -m pytest -m 'not adios2 and not petsc4py' /dolfinx/python/test/unit"
- name: Test in clean python image with pypi Intel MPI (x86_64 only)
if: runner.arch == 'X64'
run: >
cd dolfinx &&
sudo git clean -fdx && cd ../ &&
docker run -v $(pwd)/dolfinx:/dolfinx -v $(pwd)/simple:/shared \
--env PIP_EXTRA_INDEX_URL=file:///shared python:3.14 \
/bin/bash -l -c "pip install impi-rt fenics-dolfinx[test] && mpiexec -n 2 python -m pytest -m 'not adios2 and not petsc4py' /dolfinx/python/test/unit"
- name: Upload wheelhouse artifact
uses: actions/upload-artifact@v7
with:
name: wheelhouse-${{ matrix.os }}
path: wheelhouse/*
- name: Update FEniCS Project simple503 repository
run: |
python -m simple503 --base-url http://packages.fenicsproject.org/simple simple
- name: Upload simple503 artifact
uses: actions/upload-artifact@v7
with:
name: simple503-${{ matrix.os }}
path: simple/*