From e2f5b734d4dae734feb6bd7a86afb5e3ca0a3353 Mon Sep 17 00:00:00 2001 From: Benjy Weinberger Date: Mon, 18 Nov 2024 22:33:46 -0800 Subject: [PATCH] update the manylinux wheel glibc version to 2.28 (#21650) (#21660) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit While trying to land #21528 to was observed that the wheel building jobs were failing during git checkout with wonderful errors like ``/__e/node20/bin/node: /lib64/libm.so.6: version `GLIBC_2.27' not found (required by /__e/node20/bin/node)``. This appears to be the same symptoms as https://github.com/actions/checkout/issues/1809 which pointed the the deprecation notice at . If this all sounds familiar that is because we *mostly* cleaned this up in #21133, but kept a fewer uses of the older actions for `manylinux2014` compatibility. However, from the notice: "To opt out of this and continue using Node16 while it is still available in the runner, you can choose to set ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION=true as an ‘env’ in their workflow or as an environment variable on your runner machine. This will *only work until we upgrade the runner removing Node16 later in the spring*. (emphasis added)" From the wheel job failures during #21528 and my attempts to fiddle with all of `ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION`, `ACTIONS_RUNNER_FORCED_INTERNAL_NODE_VERSION`, `ACTIONS_RUNNER_FORCE_ACTIONS_NODE_VERSION` I think the removal time promised for the Spring has finally come, but I'm not that familiar with GitHub Actions and could be missing something. As a consequence the version of both `actions/upload-artifacts` and `actions/checkout` is bumped to `v4`. To make this testable now and in the future, wheels are now build on ci config changes. Why is bumping to `manylinux_2_28` (the next oldest manylinux) not a big deal? The "2.28" refers to glibc [2.28](https://sourceware.org/legacy-ml/libc-alpha/2018-08/msg00003.html) in 2018. That is older than Debian stable and if you need to use software that old you are presumably paying someone for an enterprise distribution. NOTE: I think we should bump the manylinux version in `main` regardless, but if my read if the situation is correct we may need to backport this any active release line. Without this or a more complex change we would also be unable to release after December 5th per #21616. ref #21195 #21616 Co-authored-by: cburroughs --- .github/workflows/release.yaml | 36 ++++++--- .github/workflows/test.yaml | 56 +++++++++----- .../generate_github_workflows.py | 77 ++++++++----------- 3 files changed, 94 insertions(+), 75 deletions(-) diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index 418027dd18b..7b3936688f4 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -6,7 +6,7 @@ jobs: build_wheels_linux_arm64: container: - image: quay.io/pypa/manylinux2014_aarch64:latest + image: quay.io/pypa/manylinux_2_28_aarch64:latest env: ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION: true PANTS_REMOTE_CACHE_READ: 'false' @@ -23,7 +23,7 @@ jobs: - run-id=${{ github.run_id }} steps: - name: Check out code - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: fetch-depth: 10 ref: ${{ needs.release_info.outputs.build-ref }} @@ -43,6 +43,14 @@ jobs: echo "/opt/python/cp39-cp39/bin" >> $GITHUB_PATH + echo "/opt/python/cp310-cp310/bin" >> $GITHUB_PATH + + echo "/opt/python/cp311-cp311/bin" >> $GITHUB_PATH + + echo "/opt/python/cp312-cp312/bin" >> $GITHUB_PATH + + echo "/opt/python/cp313-cp313/bin" >> $GITHUB_PATH + ' - name: Install Protoc uses: arduino/setup-protoc@9b1ee5b22b0a3f1feb8c2ff99b32c89b3c3191e9 @@ -58,7 +66,7 @@ jobs: - continue-on-error: true if: always() name: Upload pants.log - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: logs-wheels-and-pex-Linux-ARM64 overwrite: 'true' @@ -83,7 +91,7 @@ jobs: timeout-minutes: 90 build_wheels_linux_x86_64: container: - image: quay.io/pypa/manylinux2014_x86_64:latest + image: quay.io/pypa/manylinux_2_28_x86_64:latest env: ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION: true PANTS_REMOTE_CACHE_READ: 'false' @@ -96,7 +104,7 @@ jobs: - ubuntu-20.04 steps: - name: Check out code - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: fetch-depth: 10 ref: ${{ needs.release_info.outputs.build-ref }} @@ -116,6 +124,14 @@ jobs: echo "/opt/python/cp39-cp39/bin" >> $GITHUB_PATH + echo "/opt/python/cp310-cp310/bin" >> $GITHUB_PATH + + echo "/opt/python/cp311-cp311/bin" >> $GITHUB_PATH + + echo "/opt/python/cp312-cp312/bin" >> $GITHUB_PATH + + echo "/opt/python/cp313-cp313/bin" >> $GITHUB_PATH + ' - name: Install Protoc uses: arduino/setup-protoc@9b1ee5b22b0a3f1feb8c2ff99b32c89b3c3191e9 @@ -123,7 +139,7 @@ jobs: repo-token: ${{ secrets.GITHUB_TOKEN }} version: 23.x - name: Install Go - uses: actions/setup-go@v4 + uses: actions/setup-go@v5 with: go-version: 1.19.5 - env: @@ -137,7 +153,7 @@ jobs: - continue-on-error: true if: always() name: Upload pants.log - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: logs-wheels-and-pex-Linux-x86_64 overwrite: 'true' @@ -205,7 +221,7 @@ jobs: ' - name: Cache Cargo - uses: benjyw/rust-cache@461b9f8eee66b575bce78977bf649b8b7a8d53f1 + uses: benjyw/rust-cache@5ed697a6894712d2854c80635bb00a2496ea307a with: cache-bin: 'false' shared-key: engine @@ -291,7 +307,7 @@ jobs: ' - name: Cache Cargo - uses: benjyw/rust-cache@461b9f8eee66b575bce78977bf649b8b7a8d53f1 + uses: benjyw/rust-cache@5ed697a6894712d2854c80635bb00a2496ea307a with: cache-bin: 'false' shared-key: engine @@ -383,7 +399,7 @@ jobs: ' - name: Cache Cargo - uses: benjyw/rust-cache@461b9f8eee66b575bce78977bf649b8b7a8d53f1 + uses: benjyw/rust-cache@5ed697a6894712d2854c80635bb00a2496ea307a with: cache-bin: 'false' shared-key: engine diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index b39bf17cf20..8f20359e3db 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -48,7 +48,7 @@ jobs: ' - name: Cache Cargo - uses: benjyw/rust-cache@461b9f8eee66b575bce78977bf649b8b7a8d53f1 + uses: benjyw/rust-cache@5ed697a6894712d2854c80635bb00a2496ea307a with: cache-bin: 'false' shared-key: engine @@ -141,7 +141,7 @@ jobs: ' - name: Cache Cargo - uses: benjyw/rust-cache@461b9f8eee66b575bce78977bf649b8b7a8d53f1 + uses: benjyw/rust-cache@5ed697a6894712d2854c80635bb00a2496ea307a with: cache-bin: 'false' shared-key: engine @@ -244,7 +244,7 @@ jobs: ' - name: Cache Cargo - uses: benjyw/rust-cache@461b9f8eee66b575bce78977bf649b8b7a8d53f1 + uses: benjyw/rust-cache@5ed697a6894712d2854c80635bb00a2496ea307a with: cache-bin: 'false' shared-key: engine @@ -301,14 +301,14 @@ jobs: timeout-minutes: 60 build_wheels_linux_arm64: container: - image: quay.io/pypa/manylinux2014_aarch64:latest + image: quay.io/pypa/manylinux_2_28_aarch64:latest env: ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION: true MODE: debug PANTS_REMOTE_CACHE_READ: 'false' PANTS_REMOTE_CACHE_WRITE: 'false' - if: ((github.repository_owner == 'pantsbuild') && (needs.classify_changes.outputs.release == 'true')) && (needs.classify_changes.outputs.docs_only - != 'true') + if: ((github.repository_owner == 'pantsbuild') && (needs.classify_changes.outputs.release == 'true' || needs.classify_changes.outputs.ci_config + == 'true')) && (needs.classify_changes.outputs.docs_only != 'true') name: Build wheels (Linux-ARM64) needs: - classify_changes @@ -320,7 +320,7 @@ jobs: - run-id=${{ github.run_id }} steps: - name: Check out code - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: fetch-depth: 10 - name: Configure Git @@ -338,6 +338,14 @@ jobs: echo "/opt/python/cp39-cp39/bin" >> $GITHUB_PATH + echo "/opt/python/cp310-cp310/bin" >> $GITHUB_PATH + + echo "/opt/python/cp311-cp311/bin" >> $GITHUB_PATH + + echo "/opt/python/cp312-cp312/bin" >> $GITHUB_PATH + + echo "/opt/python/cp313-cp313/bin" >> $GITHUB_PATH + ' - name: Install Protoc uses: arduino/setup-protoc@9b1ee5b22b0a3f1feb8c2ff99b32c89b3c3191e9 @@ -353,7 +361,7 @@ jobs: - continue-on-error: true if: always() name: Upload pants.log - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: logs-wheels-and-pex-Linux-ARM64 overwrite: 'true' @@ -361,14 +369,14 @@ jobs: timeout-minutes: 90 build_wheels_linux_x86_64: container: - image: quay.io/pypa/manylinux2014_x86_64:latest + image: quay.io/pypa/manylinux_2_28_x86_64:latest env: ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION: true MODE: debug PANTS_REMOTE_CACHE_READ: 'false' PANTS_REMOTE_CACHE_WRITE: 'false' - if: ((github.repository_owner == 'pantsbuild') && (needs.classify_changes.outputs.release == 'true')) && (needs.classify_changes.outputs.docs_only - != 'true') + if: ((github.repository_owner == 'pantsbuild') && (needs.classify_changes.outputs.release == 'true' || needs.classify_changes.outputs.ci_config + == 'true')) && (needs.classify_changes.outputs.docs_only != 'true') name: Build wheels (Linux-x86_64) needs: - classify_changes @@ -376,7 +384,7 @@ jobs: - ubuntu-20.04 steps: - name: Check out code - uses: actions/checkout@v3 + uses: actions/checkout@v4 with: fetch-depth: 10 - name: Configure Git @@ -394,6 +402,14 @@ jobs: echo "/opt/python/cp39-cp39/bin" >> $GITHUB_PATH + echo "/opt/python/cp310-cp310/bin" >> $GITHUB_PATH + + echo "/opt/python/cp311-cp311/bin" >> $GITHUB_PATH + + echo "/opt/python/cp312-cp312/bin" >> $GITHUB_PATH + + echo "/opt/python/cp313-cp313/bin" >> $GITHUB_PATH + ' - name: Install Protoc uses: arduino/setup-protoc@9b1ee5b22b0a3f1feb8c2ff99b32c89b3c3191e9 @@ -401,7 +417,7 @@ jobs: repo-token: ${{ secrets.GITHUB_TOKEN }} version: 23.x - name: Install Go - uses: actions/setup-go@v4 + uses: actions/setup-go@v5 with: go-version: 1.19.5 - env: @@ -415,7 +431,7 @@ jobs: - continue-on-error: true if: always() name: Upload pants.log - uses: actions/upload-artifact@v3 + uses: actions/upload-artifact@v4 with: name: logs-wheels-and-pex-Linux-x86_64 overwrite: 'true' @@ -427,8 +443,8 @@ jobs: MODE: debug PANTS_REMOTE_CACHE_READ: 'false' PANTS_REMOTE_CACHE_WRITE: 'false' - if: ((github.repository_owner == 'pantsbuild') && (needs.classify_changes.outputs.release == 'true')) && (needs.classify_changes.outputs.docs_only - != 'true') + if: ((github.repository_owner == 'pantsbuild') && (needs.classify_changes.outputs.release == 'true' || needs.classify_changes.outputs.ci_config + == 'true')) && (needs.classify_changes.outputs.docs_only != 'true') name: Build wheels (macOS10-15-x86_64) needs: - classify_changes @@ -459,7 +475,7 @@ jobs: ' - name: Cache Cargo - uses: benjyw/rust-cache@461b9f8eee66b575bce78977bf649b8b7a8d53f1 + uses: benjyw/rust-cache@5ed697a6894712d2854c80635bb00a2496ea307a with: cache-bin: 'false' shared-key: engine @@ -496,8 +512,8 @@ jobs: MODE: debug PANTS_REMOTE_CACHE_READ: 'false' PANTS_REMOTE_CACHE_WRITE: 'false' - if: ((github.repository_owner == 'pantsbuild') && (needs.classify_changes.outputs.release == 'true')) && (needs.classify_changes.outputs.docs_only - != 'true') + if: ((github.repository_owner == 'pantsbuild') && (needs.classify_changes.outputs.release == 'true' || needs.classify_changes.outputs.ci_config + == 'true')) && (needs.classify_changes.outputs.docs_only != 'true') name: Build wheels (macOS11-ARM64) needs: - classify_changes @@ -528,7 +544,7 @@ jobs: ' - name: Cache Cargo - uses: benjyw/rust-cache@461b9f8eee66b575bce78977bf649b8b7a8d53f1 + uses: benjyw/rust-cache@5ed697a6894712d2854c80635bb00a2496ea307a with: cache-bin: 'false' shared-key: engine diff --git a/src/python/pants_release/generate_github_workflows.py b/src/python/pants_release/generate_github_workflows.py index 65af71b7e6d..ab05fcbb561 100644 --- a/src/python/pants_release/generate_github_workflows.py +++ b/src/python/pants_release/generate_github_workflows.py @@ -20,41 +20,28 @@ from pants.util.strutil import softwrap -def action(name: str, node16_compat: bool = False) -> str: - # Versions of actions compatible with node16 and the `ACTIONS_ALLOW_USE_UNSECURE_NODE_VERSION` setting. - # glibc 2.17 is required to build manylinux_2014 wheels, but node.js does do not ship glibc 2.17 compatible - # binaries for node >= v17. - if node16_compat: - version_map = { - "checkout": "actions/checkout@v3", - "upload-artifact": "actions/upload-artifact@v3", - "setup-go": "actions/setup-go@v4", - } - else: - version_map = { - "action-send-mail": "dawidd6/action-send-mail@v3.8.0", - "cache": "actions/cache@v4", - "checkout": "actions/checkout@v4", - "download-artifact": "actions/download-artifact@v4", - "expose-pythons": "pantsbuild/actions/expose-pythons@v9", - "github-action-required-labels": "mheap/github-action-required-labels@v4.0.0", - "rust-cache": "benjyw/rust-cache@461b9f8eee66b575bce78977bf649b8b7a8d53f1", - "setup-go": "actions/setup-go@v5", - "setup-java": "actions/setup-java@v4", - "setup-node": "actions/setup-node@v4", - "setup-protoc": "arduino/setup-protoc@9b1ee5b22b0a3f1feb8c2ff99b32c89b3c3191e9", - "setup-python": "actions/setup-python@v5", - "slack-github-action": "slackapi/slack-github-action@v1.24.0", - "upload-artifact": "actions/upload-artifact@v4", - } +def action(name: str) -> str: + version_map = { + "action-send-mail": "dawidd6/action-send-mail@v3.8.0", + "cache": "actions/cache@v4", + "checkout": "actions/checkout@v4", + "download-artifact": "actions/download-artifact@v4", + "expose-pythons": "pantsbuild/actions/expose-pythons@v9", + "github-action-required-labels": "mheap/github-action-required-labels@v4.0.0", + "rust-cache": "benjyw/rust-cache@5ed697a6894712d2854c80635bb00a2496ea307a", + "setup-go": "actions/setup-go@v5", + "setup-java": "actions/setup-java@v4", + "setup-node": "actions/setup-node@v4", + "setup-protoc": "arduino/setup-protoc@9b1ee5b22b0a3f1feb8c2ff99b32c89b3c3191e9", + "setup-python": "actions/setup-python@v5", + "slack-github-action": "slackapi/slack-github-action@v1.24.0", + "upload-artifact": "actions/upload-artifact@v4", + } try: return version_map[name] except KeyError as e: - configured_version = ( - "Node 16 compatible version configured" if node16_compat else "version configured" - ) raise ValueError( - f"Requested github action '{name}' does not have a {configured_version}.\n" + f"Requested github action '{name}' does not have a version configured.\n" f"Current known versions: {version_map}" ) from e @@ -127,7 +114,7 @@ def hash_files(path: str) -> str: PYTHON_VERSION = "3.9" DONT_SKIP_RUST = "needs.classify_changes.outputs.rust == 'true'" -DONT_SKIP_WHEELS = "needs.classify_changes.outputs.release == 'true'" +DONT_SKIP_WHEELS = "needs.classify_changes.outputs.release == 'true' || needs.classify_changes.outputs.ci_config == 'true'" IS_PANTS_OWNER = "github.repository_owner == 'pantsbuild'" # NB: This overrides `pants.ci.toml`. @@ -262,7 +249,7 @@ def checkout( # We need to fetch a few commits back, to be able to access HEAD^2 in the PR case. { "name": "Check out code", - "uses": action("checkout", node16_compat=containerized), + "uses": action("checkout"), "with": { **fetch_depth_opt, **({"ref": ref} if ref else {}), @@ -388,10 +375,10 @@ def install_jdk() -> Step: } -def install_go(node16_compat: bool = False) -> Step: +def install_go() -> Step: return { "name": "Install Go", - "uses": action("setup-go", node16_compat=node16_compat), + "uses": action("setup-go"), "with": {"go-version": "1.19.5"}, } @@ -614,10 +601,10 @@ def bootstrap_pants(self) -> Sequence[Step]: self.native_binaries_upload(), ] - def upload_log_artifacts(self, name: str, node16_compat: bool = False) -> Step: + def upload_log_artifacts(self, name: str) -> Step: return { "name": "Upload pants.log", - "uses": action("upload-artifact", node16_compat=node16_compat), + "uses": action("upload-artifact"), "if": "always()", "continue-on-error": True, "with": { @@ -866,9 +853,9 @@ def build_wheels_job( # the code, install rustup and expose Pythons. # TODO: Apply rust caching here. if platform == Platform.LINUX_X86_64: - container = {"image": "quay.io/pypa/manylinux2014_x86_64:latest"} + container = {"image": "quay.io/pypa/manylinux_2_28_x86_64:latest"} elif platform == Platform.LINUX_ARM64: - container = {"image": "quay.io/pypa/manylinux2014_aarch64:latest"} + container = {"image": "quay.io/pypa/manylinux_2_28_aarch64:latest"} else: container = None @@ -883,6 +870,10 @@ def build_wheels_job( echo "/opt/python/cp37-cp37m/bin" >> $GITHUB_PATH echo "/opt/python/cp38-cp38/bin" >> $GITHUB_PATH echo "/opt/python/cp39-cp39/bin" >> $GITHUB_PATH + echo "/opt/python/cp310-cp310/bin" >> $GITHUB_PATH + echo "/opt/python/cp311-cp311/bin" >> $GITHUB_PATH + echo "/opt/python/cp312-cp312/bin" >> $GITHUB_PATH + echo "/opt/python/cp313-cp313/bin" >> $GITHUB_PATH """ ), }, @@ -921,11 +912,7 @@ def build_wheels_job( "steps": [ *initial_steps, install_protoc(), # for prost crate - *( - [] - if platform == Platform.LINUX_ARM64 - else [install_go(node16_compat=bool(container))] - ), + *([] if platform == Platform.LINUX_ARM64 else [install_go()]), { "name": "Build wheels", "run": "./pants run src/python/pants_release/release.py -- build-wheels", @@ -936,7 +923,7 @@ def build_wheels_job( "run": "./pants package src/python/pants:pants-pex", "env": helper.platform_env(), }, - helper.upload_log_artifacts(name="wheels-and-pex", node16_compat=bool(container)), + helper.upload_log_artifacts(name="wheels-and-pex"), *( [ {