Merge pull request #21 from paultiq/sccache_simple_10_2_2025 #87
  
    
      This file contains hidden or 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: On Push Fast Tests | |
| on: push | |
| # This workflow is runnable locally for debugging: | |
| # using https://github.com/nektos/act | |
| # | |
| jobs: | |
| build_wheels: | |
| name: 'Wheel: ${{ matrix.python }}-${{ matrix.platform.os }}-${{ matrix.platform.cibw_system }}_${{ matrix.platform.arch }}' | |
| strategy: | |
| fail-fast: false | |
| matrix: | |
| python: [ cp39, cp313, cp314t ] # cp39, cp310, cp311, cp312, cp313, cp314t, | |
| platform: | |
| #- { os: windows-2025, arch: amd64, cibw_system: win } | |
| - { os: ubuntu-latest, arch: x86_64, cibw_system: manylinux } | |
| # - { os: ubuntu-24.04-arm, arch: aarch64, cibw_system: manylinux } | |
| #- { os: macos-15, arch: arm64, cibw_system: macosx } | |
| #- { os: macos-26, arch: arm64, cibw_system: macosx } | |
| # - { os: macos-15, arch: universal2, cibw_system: macosx } | |
| # - { os: macos-13, arch: x86_64, cibw_system: macosx } | |
| #exclude: | |
| # - { python: cp314t, platform: { os: windows-2025 } } | |
| runs-on: ${{ matrix.platform.os }} | |
| env: | |
| CIBW_TEST_SOURCES: tests | |
| CIBW_BEFORE_TEST_LINUX: > | |
| sccache --show-stats && | |
| uv export --only-group test --no-emit-project --output-file pylock.toml --directory {project} --quiet && | |
| uv pip install -r pylock.toml | |
| CIBW_BEFORE_TEST_MACOS: > | |
| sccache --show-stats && | |
| uv export --only-group test --no-emit-project --output-file pylock.toml --directory {project} --quiet && | |
| uv pip install -r pylock.toml | |
| CIBW_BEFORE_TEST_WINDOWS: > | |
| sccache --show-stats && | |
| uv export --only-group test --no-emit-project --output-file pylock.toml --directory {project} --quiet && | |
| uv pip install -r pylock.toml | |
| CIBW_TEST_COMMAND: > | |
| uv run -v pytest ./tests/fast --verbose --ignore=./tests/stubs --durations=5 -n 2 | |
| # && uv run -v pytest ./tests/fast/threading --durations=5 --parallel-threads=10 --iterations=5 -n 2 | |
| CMAKE_VERBOSE_MAKEFILE: "ON" | |
| SCCACHE_C_CUSTOM_CACHE_BUSTER: ${{ toJSON(matrix) }} | |
| SCCACHE_BASEDIR: "/tmp/duckdb-build" | |
| ACTIONS_CACHE_SERVICE_V2: "1" | |
| TMPDIR: "/tmp/duckdb-build" | |
| TEMP: "/tmp/duckdb-build" | |
| steps: | |
| - name: Set SCCACHE_GHA_ENABLED | |
| run: echo "SCCACHE_GHA_ENABLED=${{ env.ACT == 'true' && 'off' || 'on' }}" >> $GITHUB_ENV | |
| - name: Checkout DuckDB Python | |
| if: ${{ env.ACT != 'true' }} | |
| uses: actions/checkout@v5 | |
| with: | |
| # ref: ${{ inputs.duckdb-python-sha }} | |
| fetch-depth: 0 | |
| submodules: true | |
| - name: Checkout DuckDB | |
| if: ${{ env.ACT != 'true' && inputs['duckdb-sha'] != '' }} | |
| shell: bash | |
| continue-on-error: true # sometimes helpful when merging branch->branch | |
| run: | | |
| cd external/duckdb | |
| git fetch origin | |
| git checkout ${{ inputs.duckdb-sha }} | |
| - name: Configure Cache Env | |
| # if: ${{ env.ACT != 'true' }} | |
| uses: actions/github-script@v7 | |
| with: | |
| script: | | |
| core.exportVariable('ACTIONS_RESULTS_URL', process.env.ACTIONS_RESULTS_URL || ''); | |
| core.exportVariable('ACTIONS_RUNTIME_TOKEN', process.env.ACTIONS_RUNTIME_TOKEN || ''); | |
| # Make sure that OVERRIDE_GIT_DESCRIBE is propagated to cibuildwhel's env, also when it's running linux builds | |
| - name: Set OVERRIDE_GIT_DESCRIBE | |
| shell: bash | |
| if: ${{ inputs.set-version != '' }} | |
| run: echo "CIBW_ENVIRONMENT=OVERRIDE_GIT_DESCRIBE=${{ inputs.set-version }}" >> $GITHUB_ENV | |
| # # Install Astral UV, which will be used as build-frontend for cibuildwheel | |
| - uses: astral-sh/setup-uv@v6 | |
| if: ${{ env.ACT != 'true' }} | |
| with: | |
| # version: "0.8.19" # Version is important - it determines which Python build you get. Bump when new version of Python releases. | |
| enable-cache: false | |
| activate-environment: true | |
| cache-suffix: -${{ matrix.python }}-${{ matrix.platform.cibw_system }}_${{ matrix.platform.arch }} | |
| python-version: ${{ matrix.python }} | |
| # Used when running workflows locally | |
| - name: Install UV | |
| if: ${{ env.ACT == 'true' }} | |
| shell: bash | |
| env: | |
| TMPDIR: /tmp | |
| run: | | |
| curl -LsSf https://astral.sh/uv/install.sh | sh | |
| echo "$HOME/.local/bin" >> $GITHUB_PATH | |
| export PATH="$HOME/.local/bin:$PATH" | |
| uv --version | |
| - name: Install sccache | |
| if: ${{ matrix.platform.cibw_system == 'win' }} | |
| shell: bash | |
| # TODO: Find a better PATH dir to put this in | |
| run: | | |
| curl -L https://github.com/mozilla/sccache/releases/download/v0.10.0/sccache-v0.10.0-x86_64-pc-windows-msvc.zip -o sccache.zip | |
| unzip sccache.zip | |
| cp sccache-*/sccache.exe "C:/Strawberry/c/bin/sccache.exe" | |
| sccache --version | |
| # Load MSVC environment, needed for Windows - ninja builds | |
| - uses: ilammy/msvc-dev-cmd@v1 | |
| if: ${{ matrix.platform.cibw_system == 'win' }} | |
| with: | |
| arch: ${{ matrix.platform.arch }} | |
| - name: Build${{ inputs.testsuite != 'none' && ' and test ' || ' ' }}wheels | |
| uses: pypa/[email protected] | |
| env: | |
| CIBW_ARCHS: ${{ matrix.platform.arch == 'amd64' && 'AMD64' || matrix.platform.arch }} | |
| CIBW_BUILD: ${{ matrix.python }}-${{ matrix.platform.cibw_system }}_${{ matrix.platform.arch }} | |
| #CIBW_BUILD_FRONTEND: "build[uv]; args: --no-isolation" | |
| UV_PROJECT_ENVIRONMENT: /project/.venv | |
| #UV_NO_BUILD_ISOLATION: "true" | |
| CMAKE_C_COMPILER_LAUNCHER: "" | |
| CMAKE_CXX_COMPILER_LAUNCHER: "" | |
| # CFLAGS: "-Wno-attributes" | |
| # CXXFLAGS: "-Wno-attributes" | |
| # UV_PYTHON: ${{ matrix.python }} | |
| PYTHON_GIL: 1 | |
| CIBW_BUILD_VERBOSITY: 3 | |
| # SCCACHE Notes: | |
| # - Without the /project dir and tmpdirs (not sure exactly which mattered), the python environment is installed to a random tmp dir, which breaks | |
| # the cache key... so, only the external/duckdb would cache, and not the project itself | |
| # - GHA cache is limited to 10GB LRU. | |
| # - SCCACHE_BASEDIR is not implemented in sccache (https://github.com/mozilla/sccache/issues/35) | |
| # - Using -fdebug-prefix-map/-fmacro-prefix-map for path normalization instead (Mozilla Firefox approach) | |
| # - Mozilla bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1524662 "Support gcc/clang-like build path prefix map" | |
| # - UV creates random build-env-* dirs causing cache misses (https://github.com/astral-sh/uv/issues/13096) | |
| # - Using --no-isolation to eliminate random UV build environments | |
| # | |
| # SCCACHE_LOG: trace | |
| # SCCACHE_LOG_LEVEL: trace | |
| # RUST_LOG: trace | |
| # SCCACHE_NO_DAEMON: "1" | |
| # PYTHONPATH="/project" ("." on mac and windows) | |
| # UV_NO_BUILD_ISOLATION="true" | |
| # no-build-isolation uses the same build-env path for each build, stable paths needed for caching | |
| # SCCACHE_BASEDIR="/tmp/duckdb-build" | |
| # TMPDIR="/tmp/duckdb-build" TEMP="/tmp/duckdb-build" | |
| # UV_PROJECT_ENVIRONMENT="/project/.venv" | |
| #SCCACHE_BASEDIR="/tmp/duckdb-build" | |
| #TMPDIR="/tmp/duckdb-build" TEMP="/tmp/duckdb-build" | |
| #UV_PROJECT_ENVIRONMENT="/tmp/duckdb-build/.venv" | |
| # SCCACHE_BASEDIR="/tmp/duckdb-build" | |
| # TMPDIR="C:/tmp/duckdb-build" TEMP="C:/tmp/duckdb-build" | |
| # UV_PROJECT_ENVIRONMENT="C:/project/.venv" | |
| #CMAKE_BUILD_TYPE=RelWithDebInfo | |
| CIBW_ENVIRONMENT_WINDOWS: > | |
| SCCACHE_GHA_ENABLED=true | |
| CMAKE_BUILD_TYPE=Release | |
| PYTHONPATH="." | |
| TMPDIR="C:/tmp/duckdb-build" | |
| TEMP="C:/tmp/duckdb-build" | |
| CMAKE_ARGS="-DPython3_EXECUTABLE=C:/tmp/duckdb-build/stable-venv/Scripts/python.exe -DPython_EXECUTABLE=C:/tmp/duckdb-build/stable-venv/Scripts/python.exe -DCMAKE_PREFIX_PATH=C:/tmp/duckdb-build/stable-venv" | |
| CIBW_ENVIRONMENT_MACOS: > | |
| SCCACHE_GHA_ENABLED=true | |
| PYTHONPATH="." | |
| TMPDIR="/tmp/duckdb-build" | |
| TEMP="/tmp/duckdb-build" | |
| UV_PROJECT_ENVIRONMENT="/tmp/duckdb-build/.venv" | |
| CIBW_BUILD_DIR="/tmp/duckdb-build/build" | |
| PATH="/tmp/duckdb-build/stable-venv/bin:$PATH" | |
| CMAKE_ARGS="-DPython3_EXECUTABLE=/tmp/duckdb-build/stable-venv/bin/python -DPython_EXECUTABLE=/tmp/duckdb-build/stable-venv/bin/python -DCMAKE_PREFIX_PATH=/tmp/duckdb-build/stable-venv" | |
| CIBW_ENVIRONMENT_LINUX: > | |
| SCCACHE_GHA_ENABLED=true | |
| PYTHONPATH="/project" | |
| TMPDIR="/tmp/duckdb-build" | |
| TEMP="/tmp/duckdb-build" | |
| UV_PROJECT_ENVIRONMENT="/tmp/duckdb-build/stable-venv" | |
| CMAKE_ARGS="-DPython3_EXECUTABLE=/tmp/duckdb-build/stable-venv/bin/python -DPython_EXECUTABLE=/tmp/duckdb-build/stable-venv/bin/python -DCMAKE_PREFIX_PATH=/tmp/duckdb-build/stable-venv" | |
| CIBW_ENVIRONMENT_PASS: SCCACHE_GHA_ENABLED ACTIONS_RUNTIME_TOKEN ACTIONS_RESULTS_URL ACTIONS_CACHE_SERVICE_V2 SCCACHE_C_CUSTOM_CACHE_BUSTER SCCACHE_LOG SCCACHE_LOG_LEVEL SCCACHE_NO_DAEMON RUST_LOG SCCACHE_BASEDIR TMPDIR TEMP PIP_CACHE_DIR UV_PROJECT_ENVIRONMENT PYTHONPATH UV_NO_BUILD_ISOLATION UV_CACHE_DIR UV_PYTHON CMAKE_C_COMPILER_LAUNCHER CMAKE_CXX_COMPILER_LAUNCHER CMAKE_VERBOSE_MAKEFILE CIBW_BUILD_FRONTEND PYTHON_GIL CIBW_BUILD_VERBOSITY CIBW_BUILD_DIR VIRTUAL_ENV CMAKE_ARGS | |
| CIBW_BEFORE_BUILD_LINUX: > | |
| if [ "$(uname -m)" = "aarch64" ]; then ARCH=aarch64; else ARCH=x86_64; fi && | |
| curl -L https://github.com/mozilla/sccache/releases/download/v0.10.0/sccache-v0.10.0-${ARCH}-unknown-linux-musl.tar.gz | tar xz && | |
| cp sccache-v0.10.0-${ARCH}-unknown-linux-musl/sccache /usr/bin && | |
| sccache --show-stats && | |
| mkdir -p /tmp/duckdb-build /tmp/pip-cache && | |
| uv venv /tmp/duckdb-build/stable-venv --python "$(which python)" && | |
| uv pip install --python /tmp/duckdb-build/stable-venv/bin/python 'pybind11[global]>=2.6.0' | |
| CIBW_BEFORE_BUILD_MACOS: > | |
| mkdir -p /tmp/duckdb-build /tmp/duckdb-build/uv-cache /tmp/pip-cache && | |
| brew install sccache && | |
| rm -f /tmp/duckdb-build/stable-venv && | |
| ln -sf "$VIRTUAL_ENV" /tmp/duckdb-build/stable-venv && | |
| uv pip install scikit-build-core 'pybind11[global]>=2.6.0' setuptools-scm 'cmake>=3.29.0' 'ninja>=1.10' | |
| # Build dependencies installs needed if using no-isolation | |
| # uv pip install scikit-build-core 'pybind11[global]>=2.6.0' setuptools-scm 'cmake>=3.29.0' 'ninja>=1.10' && | |
| CIBW_BEFORE_BUILD_WINDOWS: > | |
| (mkdir "C:\tmp\duckdb-build" 2>nul & mkdir "C:\tmp\duckdb-build\uv-cache" 2>nul & mkdir "C:\tmp\pip-cache" 2>nul) && | |
| del "C:\Strawberry\c\bin\ccache.exe" 2>nul && | |
| sccache --show-stats && | |
| mklink /j "C:\tmp\duckdb-build\stable-venv" "%VIRTUAL_ENV%" && | |
| call "C:\tmp\duckdb-build\stable-venv\Scripts\activate.bat" && | |
| uv pip install "pybind11[global]>=2.6.0" | |
| # && | |
| # uv pip install scikit-build-core "pybind11[global]>=2.6.0" setuptools-scm "cmake>=3.29.0" "ninja>=1.10" | |
| - name: Upload wheel | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: wheel-${{ matrix.python }}-${{ matrix.platform.os }}_${{ matrix.platform.arch }} | |
| path: wheelhouse/*.whl | |
| compression-level: 0 |