diff --git a/ci/docker/python-wheel-manylinux.dockerfile b/ci/docker/python-wheel-manylinux.dockerfile index 452809ad09c6b..aaf96b03b4e03 100644 --- a/ci/docker/python-wheel-manylinux.dockerfile +++ b/ci/docker/python-wheel-manylinux.dockerfile @@ -66,6 +66,8 @@ COPY ci/scripts/install_ccache.sh arrow/ci/scripts/ RUN /arrow/ci/scripts/install_ccache.sh ${ccache} /usr/local # Install vcpkg +ARG GITHUB_ACTOR +ARG GITHUB_TOKEN ARG vcpkg COPY ci/vcpkg/*.patch \ ci/vcpkg/*linux*.cmake \ @@ -75,10 +77,13 @@ COPY ci/scripts/install_vcpkg.sh \ ENV VCPKG_ROOT=/opt/vcpkg ARG build_type=release ENV CMAKE_BUILD_TYPE=${build_type} \ - VCPKG_FORCE_SYSTEM_BINARIES=1 \ - VCPKG_OVERLAY_TRIPLETS=/arrow/ci/vcpkg \ + GITHUB_ACTOR="${GITHUB_ACTOR}" \ + GITHUB_TOKEN="${GITHUB_TOKEN}" \ + VCPKG_BINARY_SOURCES="clear;nuget,https://nuget.pkg.github.com/${GITHUB_ACTOR}/index.json,readwrite" \ VCPKG_DEFAULT_TRIPLET=${arch_short}-linux-static-${build_type} \ - VCPKG_FEATURE_FLAGS="manifests" + VCPKG_FEATURE_FLAGS="manifests" \ + VCPKG_FORCE_SYSTEM_BINARIES=1 \ + VCPKG_OVERLAY_TRIPLETS=/arrow/ci/vcpkg RUN arrow/ci/scripts/install_vcpkg.sh ${VCPKG_ROOT} ${vcpkg} ENV PATH="${PATH}:${VCPKG_ROOT}" @@ -93,7 +98,7 @@ RUN vcpkg install \ --clean-after-build \ --x-install-root=${VCPKG_ROOT}/installed \ --x-manifest-root=/arrow/ci/vcpkg \ - --x-feature=azure \ + --x-feature=azure \ --x-feature=flight \ --x-feature=gcs \ --x-feature=json \ diff --git a/ci/scripts/install_vcpkg.sh b/ci/scripts/install_vcpkg.sh index 08989d6444827..9c9d81bd69322 100755 --- a/ci/scripts/install_vcpkg.sh +++ b/ci/scripts/install_vcpkg.sh @@ -17,7 +17,7 @@ # specific language governing permissions and limitations # under the License. -set -e +set -eu if [ "$#" -lt 1 ]; then echo "Usage: $0 `` [ []]" @@ -42,7 +42,7 @@ pushd ${vcpkg_destination} git checkout "${vcpkg_version}" -if [[ "$OSTYPE" == "msys" ]]; then +if [[ "${OSTYPE:-}" == "msys" ]]; then ./bootstrap-vcpkg.bat -disableMetrics else ./bootstrap-vcpkg.sh -disableMetrics @@ -53,4 +53,19 @@ if [ -f "${vcpkg_ports_patch}" ]; then echo "Patch successfully applied to the VCPKG port files!" fi +if [ -n "${GITHUB_TOKEN:-}" ] && [ -n "${GITHUB_ACTOR:-}" ]; then + PATH="${PATH}:${VCPKG_ROOT}" + nuget_url="https://nuget.pkg.github.com/${GITHUB_ACTOR}/index.json" + "$(vcpkg fetch nuget)" \ + sources add \ + -Source "${nuget_url}" \ + -StorePasswordInClearText \ + -Name GitHubPackages \ + -UserName "${GITHUB_ACTOR}" \ + -Password "${GITHUB_TOKEN}" + "$(vcpkg fetch nuget)" \ + setapikey "${GITHUB_TOKEN}" \ + -Source "${nuget_url}" +fi + popd diff --git a/dev/tasks/python-wheels/github.linux.yml b/dev/tasks/python-wheels/github.linux.yml index 7a1c8fb4f9d80..b2afc93fdd523 100644 --- a/dev/tasks/python-wheels/github.linux.yml +++ b/dev/tasks/python-wheels/github.linux.yml @@ -19,6 +19,9 @@ {{ macros.github_header() }} +permissions: + packages: write + jobs: build: name: "Build wheel for manylinux {{ manylinux_version }}" @@ -49,7 +52,12 @@ jobs: - name: Build wheel shell: bash - run: archery docker run -e SETUPTOOLS_SCM_PRETEND_VERSION={{ arrow.no_rc_version }} python-wheel-manylinux-{{ manylinux_version }} + run: | + archery docker run \ + -e SETUPTOOLS_SCM_PRETEND_VERSION={{ arrow.no_rc_version }} \ + python-wheel-manylinux-{{ manylinux_version }} + env: + GITHUB_TOKEN: {{ '${{ secrets.GITHUB_TOKEN }}' }} - uses: actions/upload-artifact@v4 with: diff --git a/docker-compose.yml b/docker-compose.yml index 0882121d598bb..b5966c98bc93f 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -53,9 +53,6 @@ # # See more in cpp/build-support/run-test.sh::print_coredumps -x-common: &common - GITHUB_ACTIONS: - x-ccache: &ccache CCACHE_COMPILERCHECK: content CCACHE_COMPRESS: 1 @@ -63,6 +60,13 @@ x-ccache: &ccache CCACHE_MAXSIZE: 1G CCACHE_DIR: /ccache +x-common: &common + GITHUB_ACTIONS: + +x-cpp: &cpp + ARROW_RUNTIME_SIMD_LEVEL: + ARROW_SIMD_LEVEL: + x-sccache: &sccache AWS_ACCESS_KEY_ID: AWS_SECRET_ACCESS_KEY: @@ -70,9 +74,10 @@ x-sccache: &sccache SCCACHE_REGION: SCCACHE_S3_KEY_PREFIX: ${SCCACHE_S3_KEY_PREFIX:-sccache} -x-cpp: &cpp - ARROW_RUNTIME_SIMD_LEVEL: - ARROW_SIMD_LEVEL: +x-vcpkg-build-args: &vcpkg-build-args + vcpkg: ${VCPKG} + GITHUB_ACTOR: + GITHUB_TOKEN: # CPU/memory limit presets to pass to Docker. # @@ -1120,10 +1125,10 @@ services: image: ${REPO}:${ARCH}-python-${PYTHON}-wheel-manylinux-2014-vcpkg-${VCPKG} build: args: + <<: *vcpkg-build-args arch: ${ARCH} arch_short: ${ARCH_SHORT} base: quay.io/pypa/manylinux2014_${ARCH_ALIAS}:2024-08-03-32dfa47 - vcpkg: ${VCPKG} python: ${PYTHON} python_abi_tag: ${PYTHON_ABI_TAG} manylinux: 2014 @@ -1144,10 +1149,10 @@ services: image: ${REPO}:${ARCH}-python-${PYTHON}-wheel-manylinux-2-28-vcpkg-${VCPKG} build: args: + <<: *vcpkg-build-args arch: ${ARCH} arch_short: ${ARCH_SHORT} base: quay.io/pypa/manylinux_2_28_${ARCH_ALIAS}:2024-08-03-32dfa47 - vcpkg: ${VCPKG} python: ${PYTHON} python_abi_tag: ${PYTHON_ABI_TAG} manylinux: 2_28 @@ -1239,7 +1244,7 @@ services: image: ${REPO}:python-${PYTHON}-wheel-windows-vs2019-vcpkg-${VCPKG}-${PYTHON_WHEEL_WINDOWS_IMAGE_REVISION} build: args: - vcpkg: ${VCPKG} + <<: *vcpkg-build-args python: ${PYTHON} context: . dockerfile: ci/docker/python-wheel-windows-vs2019.dockerfile