From 184d4e12801a6db0925a44babbb2e8b8aa2cab96 Mon Sep 17 00:00:00 2001 From: Matthieu Darbois Date: Sat, 29 Jun 2024 20:12:13 +0200 Subject: [PATCH] fix(ci): CircleCI / Azure Pipelines / GitLab (#1899) * fix(ci): CircleCI CircleCI does not support Intel macOS runners anymore. c.f. https://discuss.circleci.com/t/macos-intel-support-deprecation-in-january-2024/48718 * fix(ci): Azure Pipelines * fix(ci): GitLab --- .circleci/config.yml | 13 +++++++------ .circleci/prepare.sh | 8 +++++--- .gitlab-ci.yml | 6 +++--- CI.md | 10 +++++----- azure-pipelines.yml | 2 +- examples/azure-pipelines-minimal.yml | 2 +- examples/circleci-minimal.yml | 8 +++++--- examples/gitlab-minimal.yml | 6 +++--- 8 files changed, 30 insertions(+), 25 deletions(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index 33716a9bc..5c8bef6f6 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -1,9 +1,10 @@ version: 2 jobs: - osx-python3.9: + osx-python3.12: macos: - xcode: 12.5.1 + xcode: 15.4.0 + resource_class: macos.m1.medium.gen1 environment: PYTHON: python3 steps: @@ -17,9 +18,9 @@ jobs: command: venv/bin/python ./bin/run_tests.py no_output_timeout: 30m - linux-python3.9: + linux-python3.12: docker: - - image: circleci/python:3.9 + - image: cimg/python:3.12 environment: PYTHON: python3 # Temporarily restrict the tests that are run on CircleCI to prevent @@ -61,6 +62,6 @@ workflows: version: 2 all-tests: jobs: - - osx-python3.9 - - linux-python3.9 + - osx-python3.12 + - linux-python3.12 - linux-aarch64 diff --git a/.circleci/prepare.sh b/.circleci/prepare.sh index 21a8dde60..fc16047f0 100644 --- a/.circleci/prepare.sh +++ b/.circleci/prepare.sh @@ -2,10 +2,12 @@ set -o errexit set -o xtrace +if [ "$(uname -s)" == "Darwin" ]; then + sudo softwareupdate --install-rosetta --agree-to-license +fi + $PYTHON --version -$PYTHON -m pip --version -$PYTHON -m virtualenv --version -$PYTHON -m virtualenv --no-setuptools --no-wheel -p "$PYTHON" venv +$PYTHON -m venv venv venv/bin/python -m pip install -U pip venv/bin/python -m pip install -e ".[dev]" venv/bin/python -m pip freeze diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index f503e6d5b..d6bc2f4eb 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,5 +1,5 @@ linux: - image: python:3.8 + image: python:3.12 services: - name: docker:dind entrypoint: ["env", "-u", "DOCKER_HOST"] @@ -23,9 +23,9 @@ windows: variables: PYTEST_ADDOPTS: -k "unit_test or test_0_basic" --suppress-no-test-exit-code before_script: - - choco install python -y --version 3.8.6 + - choco install python -y --version 3.12.4 script: - py -m pip install -e ".[dev]" pytest-custom-exit-code - py bin\run_tests.py tags: - - windows + - saas-windows-medium-amd64 diff --git a/CI.md b/CI.md index 846d39302..55e9105a2 100644 --- a/CI.md +++ b/CI.md @@ -1,10 +1,10 @@ This is a summary of the host Python versions and platforms covered by the different CI platforms: -| | 3.8 | 3.9 | 3.10 | 3.12 | -|---------|--------------------------------------------------------|-----------------------|-----------|----------------| -| Linux | AppVeyor¹ / Azure Pipelines / GitLab¹ / GitHub Actions | CircleCI¹ / Travis CI | Cirrus CI | GitHub Actions | -| macOS | AppVeyor¹ / Azure Pipelines | CircleCI¹ / Travis CI | Cirrus CI | GitHub Actions | -| Windows | AppVeyor¹ / Azure Pipelines / GitLab¹ | Travis CI | Cirrus CI | GitHub Actions | +| | 3.8 | 3.9 | 3.10 | 3.12 | +|---------|----------------------------------------------|-----------|-----------|--------------------------------------| +| Linux | AppVeyor¹ / Azure Pipelines / GitHub Actions | Travis CI | Cirrus CI | CircleCI¹ / GitHub Actions / GitLab¹ | +| macOS | AppVeyor¹ / Azure Pipelines | | Cirrus CI | CircleCI¹ / GitHub Actions | +| Windows | AppVeyor¹ / Azure Pipelines | Travis CI | Cirrus CI | GitHub Actions / GitLab¹ | > ¹ Runs a reduced set of tests to reduce CI load diff --git a/azure-pipelines.yml b/azure-pipelines.yml index bac19cb74..beb3d80d7 100644 --- a/azure-pipelines.yml +++ b/azure-pipelines.yml @@ -17,7 +17,7 @@ jobs: python ./bin/run_tests.py - job: macos_38 - pool: {vmImage: 'macOS-11'} + pool: {vmImage: 'macOS-12'} steps: - task: UsePythonVersion@0 inputs: diff --git a/examples/azure-pipelines-minimal.yml b/examples/azure-pipelines-minimal.yml index 488c83a06..d45344762 100644 --- a/examples/azure-pipelines-minimal.yml +++ b/examples/azure-pipelines-minimal.yml @@ -14,7 +14,7 @@ jobs: inputs: {pathtoPublish: 'wheelhouse'} - job: macos - pool: {vmImage: 'macOS-11'} + pool: {vmImage: 'macOS-12'} steps: - task: UsePythonVersion@0 - bash: | diff --git a/examples/circleci-minimal.yml b/examples/circleci-minimal.yml index b13e38e02..2b4bed88c 100644 --- a/examples/circleci-minimal.yml +++ b/examples/circleci-minimal.yml @@ -4,14 +4,14 @@ jobs: linux-wheels: working_directory: ~/linux-wheels docker: - - image: circleci/python:3.9 + - image: cimg/python:3.12 steps: - checkout - setup_remote_docker - run: name: Build the Linux wheels. command: | - pip3 install --user cibuildwheel==2.19.1 + python3 -m pip install --user cibuildwheel==2.19.1 cibuildwheel --output-dir wheelhouse - store_artifacts: path: wheelhouse/ @@ -36,12 +36,14 @@ jobs: osx-wheels: working_directory: ~/osx-wheels macos: - xcode: 12.5.1 + xcode: 15.4.0 + resource_class: macos.m1.medium.gen1 steps: - checkout - run: name: Build the OS X wheels. command: | + sudo softwareupdate --install-rosetta --agree-to-license # for python<=3.8 or x86_64/universal2 tests pip3 install cibuildwheel==2.19.1 cibuildwheel --output-dir wheelhouse - store_artifacts: diff --git a/examples/gitlab-minimal.yml b/examples/gitlab-minimal.yml index 9682a8015..7c16683ef 100644 --- a/examples/gitlab-minimal.yml +++ b/examples/gitlab-minimal.yml @@ -1,5 +1,5 @@ linux: - image: python:3.8 + image: python:3.12 # make a docker daemon available for cibuildwheel to use services: - name: docker:dind @@ -21,7 +21,7 @@ linux: windows: image: mcr.microsoft.com/windows/servercore:1809 before_script: - - choco install python -y --version 3.8.6 + - choco install python -y --version 3.12.4 - choco install git.install -y - py -m pip install cibuildwheel==2.19.1 script: @@ -30,4 +30,4 @@ windows: paths: - wheelhouse/ tags: - - windows + - saas-windows-medium-amd64