Upgrade to pyarrow 17.0.0 #707
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Continuous Integration | |
on: | |
push: | |
branches: | |
- main | |
tags: | |
- "*" | |
pull_request: | |
schedule: | |
- cron: '30 2 * * 1,4' # Every Monday and Thursday @ 2h30am UTC | |
env: | |
CIBW_BUILD_FRONTEND: build | |
CIBW_BEFORE_ALL_LINUX: yum install -y zip flex bison gcc-gfortran | |
# Need to reinstall gcc in order to get gfortran | |
CIBW_BEFORE_ALL_MACOS: | | |
brew install python llvm | |
brew reinstall gcc | |
CIBW_BEFORE_BUILD_MACOS: | | |
export PATH="/opt/homebrew/opt/llvm/bin:$PATH" | |
export LDFLAGS="-L/opt/homebrew/opt/llvm/lib" | |
export CPPFLAGS="-I/opt/homebrew/opt/llvm/include" | |
CIBW_MANYLINUX_X86_64_IMAGE: quay.io/pypa/manylinux_2_28_x86_64:2024.07.02-0 | |
CIBW_TEST_EXTRAS_LINUX: applications,test | |
CIBW_TEST_COMMAND_LINUX: py.test -s -vvv --pyargs arcae | |
CIBW_TEST_COMMAND_MACOS: python -c "from arcae.testing import sanity; sanity()" | |
HOST_PYTHON_VERSION: "3.10" | |
VCPKG_INSTALLED_DIR: /tmp/vcpkg_installed | |
ARTIFACT_NAME: wheel | |
jobs: | |
build-sdist: | |
name: Build Source Distribution | |
runs-on: ubuntu-latest | |
if: "!contains(github.event.head_commit.message, '[skip ci]')" | |
steps: | |
- name: Set up Python ${{ env.HOST_PYTHON_VERSION }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ env.HOST_PYTHON_VERSION }} | |
- name: Upgrade pip and install build | |
run: python -m pip install -U pip build | |
- name: Checkout source | |
uses: actions/checkout@v4 | |
- name: Build source distribution | |
run: python -m build --sdist | |
- name: Upload wheel artifacts | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ${{ env.ARTIFACT_NAME }}-source | |
path: ./dist/*.tar.gz | |
cpp-tests: | |
name: Execute C++ test cases | |
runs-on: ubuntu-latest | |
if: "!contains(github.event.head_commit.message, '[skip ci]')" | |
strategy: | |
fail-fast: false | |
env: | |
VCPKG_TARGET_TRIPLET: "x64-linux-dynamic-cxx17-abi1-rel" | |
steps: | |
- name: Checkout source | |
uses: actions/checkout@v4 | |
- name: Set up Python ${{ env.HOST_PYTHON_VERSION }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ env.HOST_PYTHON_VERSION }} | |
- name: Expose GitHub Runtime | |
uses: crazy-max/ghaction-github-runtime@v3 | |
- name: List directory structure | |
run: tree | |
- name: Install C++ Compiler and cmake | |
run: | | |
sudo apt update | |
sudo apt install build-essential cmake | |
python -m pip install -U pip | |
python -m pip install pyarrow | |
- name: Build C++ libraries and tests | |
env: | |
VCPKG_BINARY_SOURCES: clear;x-gha,readwrite | |
VCPKG_TARGET_TRIPLET: ${{ env.VCPKG_TARGET_TRIPLET }} | |
run: | | |
cmake -S . -B build | |
cmake --build build | |
- name: Execute C++ tests | |
run: | | |
cd build | |
ctest --verbose | |
# - name: Debug with tmate on failure | |
# if: ${{ failure() }} | |
# uses: mxschmitt/action-tmate@v3 | |
build-wheels: | |
name: Build and Test Binary Wheels | |
runs-on: ${{ matrix.os }} | |
if: "!contains(github.event.head_commit.message, '[skip ci]')" | |
strategy: | |
fail-fast: false | |
matrix: | |
os: ["ubuntu-22.04", "macos-13", "macos-14"] | |
# https://peps.python.org/pep-0425 | |
cpython: ["cp39", "cp310", "cp311", "cp312"] | |
is_main_or_release: | |
- ${{ contains(github.ref, 'main') || startsWith(github.ref, 'refs/tags')}} | |
# Avoid building all wheels in a PR | |
exclude: | |
- is_main_or_release: false | |
cpython: cp39 | |
- is_main_or_release: false | |
cpython: cp310 | |
- is_main_or_release: false | |
cpython: cp312 | |
include: | |
- os: ubuntu-22.04 | |
os_short: linux | |
arch: "x86_64" | |
triplet: "x64-linux-dynamic-cxx17-abi1-rel" | |
extra_build: "manylinux_x86_64" | |
- os: macos-13 | |
os_short: macos | |
arch: "x86_64" | |
triplet: "x64-osx-dynamic-cxx17-abi1-rel" | |
extra_build: "macosx_x86_64" | |
- os: macos-14 | |
os_short: macos | |
arch: "arm64" | |
triplet: "arm64-osx-dynamic-cxx17-abi1-rel" | |
extra_build: "macosx_arm64" | |
steps: | |
- name: Set up Python ${{ env.HOST_PYTHON_VERSION }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ env.HOST_PYTHON_VERSION }} | |
- name: Upgrade pip and install virtualenv | |
run: python -m pip install -U pip virtualenv | |
- name: Checkout source | |
uses: actions/checkout@v4 | |
- name: Expose GitHub Runtime | |
uses: crazy-max/ghaction-github-runtime@v3 | |
- name: Set Common Build Environment Variable | |
env: | |
COMMON_ENV: > | |
CMAKE_ARGS=-DBUILD_TESTING=OFF | |
ACTIONS_CACHE_URL=${{ env.ACTIONS_CACHE_URL }} | |
ACTIONS_RUNTIME_TOKEN=${{ env.ACTIONS_RUNTIME_TOKEN }} | |
VCPKG_BINARY_SOURCES="clear;x-gha,readwrite" | |
VCPKG_TARGET_TRIPLET=${{ matrix.triplet }} | |
VCPKG_INSTALLED_DIR=${{ env.VCPKG_INSTALLED_DIR }} | |
LD_LIBRARY_PATH=${{ env.VCPKG_INSTALLED_DIR }}/${{ matrix.triplet }}/lib | |
run: echo "CIBW_ENVIRONMENT_COMMON=$COMMON_ENV" >> $GITHUB_ENV | |
- name: Run cibuildwheel | |
uses: pypa/[email protected] | |
env: | |
CIBW_BUILD: ${{ matrix.cpython }}-${{ matrix.extra_build }}* | |
CIBW_ARCHS: ${{ matrix.arch }} | |
CIBW_ENVIRONMENT_LINUX: ${{ env.CIBW_ENVIRONMENT_COMMON }} | |
CIBW_ENVIRONMENT_MACOS: > | |
${{ env.CIBW_ENVIRONMENT_COMMON }} | |
MACOSX_DEPLOYMENT_TARGET=11.0 | |
CIBW_REPAIR_WHEEL_COMMAND_LINUX: > | |
auditwheel repair | |
-w {dest_dir} {wheel} | |
--exclude libarrow_python.so | |
--exclude libarrow.so.1700 | |
CIBW_REPAIR_WHEEL_COMMAND_MACOS: | | |
DYLD_LIBRARY_PATH=$LD_LIBRARY_PATH delocate-listdeps {wheel} | |
DYLD_LIBRARY_PATH=$LD_LIBRARY_PATH delocate-wheel \ | |
--require-archs {delocate_archs} \ | |
-w {dest_dir} \ | |
-v {wheel} \ | |
--exclude libarrow_python.dylib \ | |
--exclude libarrow.1700.dylib \ | |
--ignore-missing-dependencies | |
- name: Upload wheel artifacts | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ${{ env.ARTIFACT_NAME }}-${{ matrix.os_short }}-${{ matrix.cpython }}-${{ matrix.arch }} | |
path: ./wheelhouse/*.whl | |
# - name: Debug with tmate on failure | |
# if: ${{ failure() }} | |
# uses: mxschmitt/action-tmate@v3 | |
upload-to-test-pypi: | |
name: Upload release to Test PyPI | |
needs: [build-sdist, build-wheels] | |
runs-on: ubuntu-latest | |
environment: | |
name: release-test | |
permissions: | |
id-token: write | |
steps: | |
- name: Download distribution artifacts | |
uses: actions/download-artifact@v4 | |
with: | |
pattern: ${{ env.ARTIFACT_NAME }}-* | |
merge-multiple: true | |
path: dist | |
- name: List artifacts | |
run: ls -lh dist | |
- name: Publish package distributions to Test PyPI | |
uses: pypa/gh-action-pypi-publish@release/v1 | |
with: | |
repository-url: https://test.pypi.org/legacy/ | |
skip-existing: true | |
continue-on-error: true | |
upload-to-pypi: | |
name: Upload release to PyPI | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags') | |
needs: [build-sdist, build-wheels] | |
runs-on: ubuntu-latest | |
environment: | |
name: release | |
permissions: | |
id-token: write | |
steps: | |
- name: Download distribution artifacts | |
uses: actions/download-artifact@v4 | |
with: | |
pattern: ${{ env.ARTIFACT_NAME }}-* | |
merge-multiple: true | |
path: dist | |
- name: List artifacts | |
run: ls -lh dist | |
- name: Publish package distributions to PyPI | |
uses: pypa/gh-action-pypi-publish@release/v1 |