Skip to content

cd-wheel

cd-wheel #50

Workflow file for this run

name: cd-wheel
permissions:
contents: read
on:
workflow_call:
inputs:
repository:
description: 'mpi4py repository'
default: mpi4py/mpi4py
required: false
type: string
ref:
description: 'mpi4py ref'
default: ''
required: false
type: string
os-arch:
description: 'Target OS-Architecture'
default: ''
required: false
type: string
python-tag:
description: "CPython/PyPy tag ({cp,pp}3{7..12})"
default: ''
required: false
type: string
skip-tag:
description: "Skip build tags"
default: ''
required: false
type: string
workflow_dispatch:
inputs:
repository:
description: 'mpi4py repository'
default: mpi4py/mpi4py
required: true
type: string
ref:
description: 'mpi4py ref'
default: ''
required: false
type: string
os-arch:
description: "Target OS-Architecture"
default: Linux-x86_64
required: true
type: choice
options:
- Linux
- Linux-x86_64
- Linux-aarch64
- Linux-ppc64le
- macOS
- macOS-x86_64
- macOS-arm64
- Windows
- Windows-AMD64
python-tag:
description: "CPython/PyPy tag ({cp,pp}3{7..12})"
default: ''
required: false
type: string
skip-tag:
description: "Skip build tags"
default: ''
required: false
type: string
jobs:
setup:
runs-on: 'ubuntu-latest'
outputs:
matrix-build: ${{ steps.setup.outputs.matrix-build }}
matrix-merge: ${{ steps.setup.outputs.matrix-merge }}
os-arch-list: ${{ steps.setup.outputs.os-arch-list }}
steps:
- uses: actions/checkout@v4
- id: setup
run: |
# build matrix
python -u .cibw/setup-build.py \
--os ${{ inputs.os-arch }} \
--py ${{ inputs.python-tag }} \
>> "$GITHUB_OUTPUT"
build:
if: ${{ needs.setup.outputs.matrix-build != '[]' }}
needs: setup
runs-on: ${{ (matrix.os == 'Linux' && 'ubuntu-latest') ||
(matrix.os == 'macOS' && 'macos-11' ) ||
(matrix.os == 'Windows' && 'windows-2019' ) }}
strategy:
fail-fast: false
matrix:
include: ${{ fromJSON(needs.setup.outputs.matrix-build) }}
steps:
- id: checkout
uses: actions/checkout@v4
- id: checkout-project
uses: actions/checkout@v4
with:
repository: ${{ inputs.repository || 'mpi4py/mpi4py' }}
ref: ${{ inputs.ref }}
path: mpi4py.git
- id: setup-python
uses: actions/setup-python@v4
with:
python-version: 3
- id: setup-cython
run: python -m pip install -r ./conf/requirements-build-cython.txt
working-directory: mpi4py.git
- id: setup-project
run: python ./conf/cythonize.py
working-directory: mpi4py.git
- id: source-date-epoch
run: |
SOURCE_DATE_EPOCH=$(git log -1 --pretty=%ct)
echo SOURCE_DATE_EPOCH=$SOURCE_DATE_EPOCH >> $GITHUB_ENV
echo $(git log -1 --pretty=%ci) [timestamp=$SOURCE_DATE_EPOCH]
shell: bash
working-directory: mpi4py.git
- id: setup-qemu
if: ${{ runner.os == 'Linux' }}
uses: docker/setup-qemu-action@v3
with:
platforms: all
- id: build
uses: pypa/[email protected]
timeout-minutes: 30
with:
package-dir: mpi4py.git
output-dir: wheelhouse
env:
MPI4PY_LOCAL_VERSION: "${{ matrix.mpi-abi }}"
CIBW_PROJECT_REQUIRES_PYTHON: ">=3.6"
CIBW_BUILD_FRONTEND: "build"
CIBW_BUILD: "${{ matrix.py || '*' }}-*"
CIBW_SKIP: "${{ inputs.skip-tag }} *musllinux*"
CIBW_ARCHS: "${{ matrix.arch }}"
CIBW_BEFORE_ALL: >-
bash {project}/.cibw/install-mpi.sh
"${{ matrix.mpi-abi }}" "${{ matrix.arch }}"
CIBW_BEFORE_BUILD: >-
bash {project}/.cibw/patch-tools.sh
CIBW_TEST_COMMAND: >-
bash {project}/.cibw/run-tests.sh
CIBW_TEST_SKIP: "*-macosx_arm64"
CIBW_ENVIRONMENT_PASS_LINUX: >-
MPI4PY_LOCAL_VERSION
MPI4PY_DIST_SUFFIX
SOURCE_DATE_EPOCH
CIBW_ENVIRONMENT_LINUX: >-
CFLAGS="-g0 -O"
CIBW_ENVIRONMENT_MACOS: >-
CFLAGS="-g0 -O"
LDFLAGS="-Wl,-headerpad_max_install_names"
LDFLAGS="$LDFLAGS -Wl,-rpath,/usr/local/lib"
LDFLAGS="$LDFLAGS -Wl,-rpath,/opt/homebrew/lib"
LDFLAGS="$LDFLAGS -Wl,-rpath,/opt/local/lib"
CIBW_ENVIRONMENT_WINDOWS: >-
I_MPI_ROOT="$USERPROFILE\\mpi\\Library"
MSMPI_ROOT="$USERPROFILE\\mpi\\Library"
MSMPI_BIN="$MSMPI_ROOT\\bin"
MSMPI_INC="$MSMPI_ROOT\\include"
MSMPI_LIB64="$MSMPI_ROOT\\lib"
CIBW_BEFORE_BUILD_WINDOWS:
- id: check
run: .cibw/check-wheels.sh wheelhouse
shell: bash
- id: upload
uses: actions/upload-artifact@v3
with:
name: build-${{ runner.os }}-${{ matrix.arch }}
path: wheelhouse/*.whl
merge:
if: ${{ needs.setup.outputs.matrix-merge != '[]' }}
needs: [setup, build]
runs-on: ${{ (matrix.os == 'Linux' && 'ubuntu-latest' ) ||
(matrix.os == 'macOS' && 'macos-latest' ) ||
(matrix.os == 'Windows' && 'windows-latest' ) }}
strategy:
fail-fast: false
matrix:
include: ${{ fromJSON(needs.setup.outputs.matrix-merge) }}
steps:
- id: checkout
uses: actions/checkout@v4
- id: checkout-project
uses: actions/checkout@v4
with:
repository: ${{ inputs.repository || 'mpi4py/mpi4py' }}
ref: ${{ inputs.ref }}
path: mpi4py.git
- id: source-date-epoch
run: |
SOURCE_DATE_EPOCH=$(git log -1 --pretty=%ct)
echo SOURCE_DATE_EPOCH=$SOURCE_DATE_EPOCH >> $GITHUB_ENV
echo $(git log -1 --pretty=%ci) [timestamp=$SOURCE_DATE_EPOCH]
shell: bash
working-directory: mpi4py.git
- id: setup-python
uses: actions/setup-python@v4
with:
python-version: 3
- id: install
run: python -m pip install -U wheel
- id: download
uses: actions/download-artifact@v3
with:
name: build-${{ runner.os }}-${{ matrix.arch }}
path: wheelhouse
- id: merge
run: python .cibw/merge-wheels.py wheelhouse dist
- id: sha256sum
run: |
# sha256sum
test $(uname) == Darwin && sha256sum() { shasum -a 256 $@; } || true
echo '```' >> $GITHUB_STEP_SUMMARY
sha256sum -b *.whl >> $GITHUB_STEP_SUMMARY
echo '```' >> $GITHUB_STEP_SUMMARY
shell: bash
working-directory: dist
- id: upload
uses: actions/upload-artifact@v3
with:
name: wheel-${{ runner.os }}
path: dist/*.whl
test-Linux:
if: ${{ contains(needs.setup.outputs.os-arch-list, 'Linux') }}
needs: [setup, merge]
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
image:
- debian:10
- debian:11
- debian:12
- ubuntu:20.04
- ubuntu:22.04
- ubuntu:23.10
- fedora:37
- fedora:38
platform:
- amd64
- arm64
- ppc64le
steps:
- uses: actions/checkout@v4
- uses: actions/download-artifact@v3
with:
name: wheel-${{ runner.os }}
path: dist
- if: ${{ runner.os == 'Linux' }}
uses: docker/setup-qemu-action@v1
with:
platforms: all
- if: ${{ runner.os == 'Linux' }}
run: |
image=${{ matrix.image }} platform=${{ matrix.platform }}
arch=$(echo $platform | sed s/amd/x86_ | sed s/arm/aarch)
ls dist | grep -q $arch || exit 0
docker run \
--rm \
--volume $(pwd):$(pwd) \
--workdir $(pwd) \
--platform linux/$platform $image \
/bin/bash .cibw/test-Linux.sh
test-macOS:
if: contains(needs.setup.outputs.os-arch-list, 'macOS-x86_64')
needs: [setup, merge]
runs-on: ${{ matrix.runner }}
strategy:
fail-fast: false
matrix:
runner:
- macos-11
- macos-12
- macos-13
defaults:
run:
shell: bash
steps:
- uses: actions/checkout@v4
- uses: actions/download-artifact@v3
with:
name: wheel-${{ runner.os }}
path: dist
- run: .cibw/test-${{ runner.os }}.sh
test-Windows:
if: contains(needs.setup.outputs.os-arch-list, 'Windows-AMD64')
needs: [setup, merge]
runs-on: ${{ matrix.runner }}
strategy:
fail-fast: false
matrix:
runner:
- windows-2019
- windows-2022
defaults:
run:
shell: bash
steps:
- uses: actions/checkout@v4
- uses: actions/download-artifact@v3
with:
name: wheel-${{ runner.os }}
path: dist
- if: ${{ runner.os != 'Windows' }}
run: .cibw/test-${{ runner.os }}.sh
- if: ${{ runner.os == 'Windows' }}
uses: actions/setup-python@v4
with:
update-environment: false
python-version: |
3.8
3.9
3.10
3.11
3.12
pypy3.8
pypy3.9
pypy3.10
- if: ${{ runner.os == 'Windows' }}
run: |
# setup Python versions
setup-python() {
local name="$1"
local version="${2:-}"
if [[ -z "$version" ]]; then
echo "$name=" >> $GITHUB_ENV; return 0
fi
local root="$RUNNER_TOOL_CACHE"
if [[ "$(uname)" =~ NT ]]; then
local root=$(cygpath -u "$root")
fi
if [[ "$name" =~ pypy ]]; then
local pydir=PyPy pyarch=x86
else
local pydir=Python pyarch=x64
fi
local path=$(ls "$root"/$pydir/${version}.*/$pyarch/python.exe)
echo "$name=$path" >> $GITHUB_ENV;
}
setup-python python36 ""
setup-python python37 ""
setup-python python38 3.8
setup-python python39 3.9
setup-python python310 3.10
setup-python python311 3.11
setup-python python312 3.12
setup-python pypy36 ""
setup-python pypy37 ""
setup-python pypy38 3.8
setup-python pypy39 3.9
setup-python pypy310 3.10
- if: ${{ runner.os == 'Windows' }}
uses: mpi4py/setup-mpi@v1
with:
mpi: intelmpi
- if: ${{ runner.os == 'Windows' }}
uses: mpi4py/setup-mpi@v1
with:
mpi: msmpi
- run: .cibw/test-${{ runner.os }}.sh
# test-setup:
# needs: [setup, merge]
# runs-on: 'ubuntu-latest'
# outputs:
# matrix-test-cf: ${{ steps.setup.outputs.matrix-test-cf }}
# matrix-test-gh: ${{ steps.setup.outputs.matrix-test-gh }}
# steps:
# - uses: actions/checkout@v4
# - if: ${{ contains(needs.setup.outputs.os-arch-list, '"Linux-x86_64"') }}
# uses: actions/download-artifact@v3
# with:
# name: build-Linux-x86_64
# path: wheelhouse
# - if: ${{ contains(needs.setup.outputs.os-arch-list, '"macOS-x86_64"') }}
# uses: actions/download-artifact@v3
# with:
# name: build-macOS-x86_64
# path: wheelhouse
# - if: ${{ contains(needs.setup.outputs.os-arch-list, '"Windows-AMD64"') }}
# uses: actions/download-artifact@v3
# with:
# name: build-Windows-AMD64
# path: wheelhouse
# - id: setup
# run: python -u .cibw/setup-test.py wheelhouse >> "$GITHUB_OUTPUT"
#
# test-cf:
# if: ${{ needs.test-setup.outputs.matrix-test-cf != '[]' }}
# needs: test-setup
# runs-on: ${{ (matrix.os == 'Linux' && 'ubuntu-latest' ) ||
# (matrix.os == 'macOS' && 'macos-latest' ) ||
# (matrix.os == 'Windows' && 'windows-latest') }}
# strategy:
# fail-fast: false
# matrix:
# include: ${{ fromJSON(needs.test-setup.outputs.matrix-test-cf) }}
#
# defaults:
# run:
# shell: bash -el {0}
#
# steps:
#
# - name: Configure hostname
# run: echo 127.0.0.1 `hostname` | sudo tee -a /etc/hosts > /dev/null
# if: runner.os == 'Linux' || runner.os == 'macOS'
#
# - uses: actions/checkout@v4
#
# - uses: mamba-org/setup-micromamba@v1
# with:
# init-shell: bash
# post-cleanup: none
# environment-name: test
# create-args: >-
# ${{ matrix.mpi }}=${{ matrix.mpi-version }}
# python=${{ matrix.py }}
# pip
# condarc: |
# show_channel_urls: true
# channel_priority: >-
# ${{ matrix.mpi == 'impi_rt' && 'flexible' || 'strict' }}
# channels:
# - conda-forge
# - ${{ matrix.mpi == 'impi_rt' && 'intel' || 'nodefaults' }}
# - nodefaults
#
# - run: |
# # Tweak MPI runtime
# case $(uname)-${{ matrix.mpi }} in
# Linux-*)
# ;;
# Darwin-*)
# ;;
# *NT*-impi_rt)
# I_MPI_ROOT=$(cygpath -w "$CONDA_PREFIX/Library")
# echo "I_MPI_ROOT=$I_MPI_ROOT" >> $GITHUB_ENV
# echo "$I_MPI_ROOT\\bin" >> $GITHUB_PATH
# echo "$I_MPI_ROOT\\bin\\libfabric" >> $GITHUB_PATH
# ;;
# *NT*-msmpi)
# MSMPI_ROOT=$(cygpath -w "$CONDA_PREFIX/Library")
# echo "MSMPI_BIN=$MSMPI_ROOT\\bin" >> $GITHUB_ENV
# echo "MSMPI_INC=$MSMPI_ROOT\\include" >> $GITHUB_ENV
# echo "MSMPI_LIB64=$MSMPI_ROOT\\lib" >> $GITHUB_ENV
# echo "$MSMPI_BIN" >> $GITHUB_PATH
# ;;
# esac
#
# - uses: actions/download-artifact@v3
# with:
# name: wheel-${{ runner.os }}
# path: dist
#
# - run: python -m pip install mpi4py --no-index --find-links=dist
#
# - uses: ./.github/actions/mpi4py-test-basic
# timeout-minutes: 2
# with:
# shell: bash -el {0}
#
# - if: ${{ matrix.mpi == 'mpich' || matrix.mpi == 'openmpi' }}
# uses: ./.github/actions/mpi4py-test-basic
# timeout-minutes: 2
# env:
# MPI4PY_MPIABI: mpi31-${{ matrix.mpi }}
# with:
# shell: bash -el {0}
#
# test-gh:
# if: ${{ needs.test-setup.outputs.matrix-test-gh != '[]' }}
# needs: test-setup
# runs-on: ${{ matrix.runner }}
# strategy:
# fail-fast: false
# matrix:
# include: ${{ fromJSON(needs.test-setup.outputs.matrix-test-gh) }}
#
# steps:
#
# - name: Configure hostname
# run: echo 127.0.0.1 `hostname` | sudo tee -a /etc/hosts > /dev/null
# if: runner.os == 'Linux' || runner.os == 'macOS'
#
# - uses: actions/checkout@v4
#
# - uses: mpi4py/setup-mpi@v1
# with:
# mpi: ${{ matrix.mpi }}
#
# - if: ${{ matrix.mpi == 'mpich' && runner.os == 'Linux' }}
# run: cd /usr/lib/$(gcc -print-multiarch) && sudo ln -s libmpi{ch,}.so.12
#
# - uses: actions/setup-python@v4
# with:
# python-version: ${{ matrix.py }}
#
# - run: python -m pip install --upgrade pip
#
# - uses: actions/download-artifact@v3
# with:
# name: wheel-${{ runner.os }}
# path: dist
#
# - run: python -m pip install mpi4py --no-index --find-links=dist
#
# - uses: ./.github/actions/mpi4py-test-basic
# timeout-minutes: 2
#
# - if: ${{ matrix.mpi == 'mpich' || matrix.mpi == 'openmpi' }}
# uses: ./.github/actions/mpi4py-test-basic
# timeout-minutes: 2
# env:
# MPI4PY_MPIABI: mpi31-${{ matrix.mpi }}