From 2f6bf6738908f3bcb1c3212c048b0d8909fca2bc Mon Sep 17 00:00:00 2001 From: Aaron Shaw <shawaj@gmail.com> Date: Mon, 10 Apr 2023 16:43:34 +0100 Subject: [PATCH] wheels: add arm64 builds and bump action versions - add arm64, ppc64le, s390x builds via qemu - add macos universal2 build - add windows arm64 build - bump cancel workflow action to latest to remove nodejs warnings - bump cibuildwheel action to latest Signed-off-by: Aaron Shaw <shawaj@gmail.com> --- .github/workflows/build.yml | 52 +++++++++++++++++++++++++++++++++---- pyproject.toml | 11 ++++++-- setup.py | 3 ++- 3 files changed, 58 insertions(+), 8 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index eb6996daa..3cbb8eb7e 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -16,6 +16,7 @@ # * https://github.com/actions/upload-artifact # * https://github.com/marketplace/actions/cancel-workflow-action # * https://github.com/vmactions/freebsd-vm +# * https://github.com/marketplace/actions/docker-setup-qemu on: [push, pull_request] name: build @@ -32,15 +33,17 @@ jobs: - os: ubuntu-latest archs: "x86_64 i686" - os: macos-12 - archs: "x86_64 arm64" + archs: "x86_64 arm64 universal2" - os: windows-2019 archs: "AMD64" + - os: windows-2019 + archs: "ARM64" - os: windows-2019 archs: "x86" steps: - name: Cancel previous runs - uses: styfle/cancel-workflow-action@0.9.1 + uses: styfle/cancel-workflow-action@0.11.0 with: access_token: ${{ github.token }} @@ -50,7 +53,7 @@ jobs: python-version: 3.11 - name: Create wheels + run tests - uses: pypa/cibuildwheel@v2.11.2 + uses: pypa/cibuildwheel@v2.12.1 env: CIBW_ARCHS: "${{ matrix.archs }}" @@ -67,6 +70,45 @@ jobs: python setup.py sdist mv dist/psutil*.tar.gz wheelhouse/ + py3-qemu: + name: py3-qemu-${{ matrix.os }}-all + runs-on: ${{ matrix.os }} + timeout-minutes: 20 + strategy: + fail-fast: false + matrix: + include: + - os: ubuntu-latest + archs: "aarch64 ppc64le s390x" + + steps: + - name: Cancel previous runs + uses: styfle/cancel-workflow-action@0.11.0 + with: + access_token: ${{ github.token }} + + - uses: actions/checkout@v3 + - uses: actions/setup-python@v4 + with: + python-version: 3.11 + + - name: Set up QEMU + uses: docker/setup-qemu-action@v2 + with: + platforms: all + + - name: Create wheels + run tests + uses: pypa/cibuildwheel@v2.12.1 + env: + CIBW_ARCHS: "${{ matrix.archs }}" + CIBW_TEST_SKIP: "*-*linux_{aarch64,ppc64le,s390x}" + + - name: Upload wheels + uses: actions/upload-artifact@v3 + with: + name: wheels + path: wheelhouse + # Linux + macOS + Python 2 py2: name: py2-${{ matrix.os }} @@ -85,7 +127,7 @@ jobs: steps: - name: Cancel previous runs - uses: styfle/cancel-workflow-action@0.9.1 + uses: styfle/cancel-workflow-action@0.11.0 with: access_token: ${{ github.token }} @@ -115,7 +157,7 @@ jobs: runs-on: macos-12 steps: - name: Cancel previous runs - uses: styfle/cancel-workflow-action@0.9.1 + uses: styfle/cancel-workflow-action@0.11.0 with: access_token: ${{ github.token }} diff --git a/pyproject.toml b/pyproject.toml index 8d68131c9..2eca86317 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -77,7 +77,7 @@ requires = ["setuptools>=43", "wheel"] build-backend = "setuptools.build_meta" [tool.cibuildwheel] -skip = ["pp*", "*-musllinux*"] +skip = "pp*" test-extras = "test" test-command = [ "env PYTHONWARNINGS=always PYTHONUNBUFFERED=1 PSUTIL_DEBUG=1 PSUTIL_SCRIPTS_DIR={project}/scripts python {project}/psutil/tests/runner.py", @@ -85,4 +85,11 @@ test-command = [ ] [tool.cibuildwheel.macos] -archs = ["x86_64", "arm64"] +archs = ["x86_64", "arm64", "universal2"] + +[tool.cibuildwheel.linux] +before-all = "yum install -y net-tools" + +[[tool.cibuildwheel.overrides]] +select = "*-musllinux*" +before-all = "apk --no-cache add coreutils procps" diff --git a/setup.py b/setup.py index 4e6f6f170..f0ff1c800 100755 --- a/setup.py +++ b/setup.py @@ -470,7 +470,8 @@ def main(): elif which('rpm'): missdeps("sudo yum install gcc %s%s-devel" % (pyimpl, py3)) elif which('apk'): - missdeps("sudo apk add gcc %s%s-dev" % (pyimpl, py3)) + missdeps("sudo apk add gcc musl-dev linux-headers %s%s-dev" + % (pyimpl, py3)) elif MACOS: print(hilite("XCode (https://developer.apple.com/xcode/) " "is not installed"), color="red", file=sys.stderr)