add benchmark to test different chunk/shard/compression/storage confi… #17
Workflow file for this run
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: Release | |
on: | |
push: | |
tags: | |
- "v*.*.*" | |
- "nightly" | |
env: | |
BUILD_TYPE: Release | |
jobs: | |
windows-and-linux-build: | |
name: Build on ${{ matrix.platform }} | |
strategy: | |
matrix: | |
platform: | |
- "windows-latest" | |
- "ubuntu-latest" | |
include: | |
- platform: "windows-latest" | |
vcpkg_triplet: "x64-windows-static" | |
- platform: "ubuntu-latest" | |
vcpkg_triplet: "x64-linux" | |
runs-on: ${{ matrix.platform }} | |
permissions: | |
actions: write | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }}-${{ matrix.platform }} | |
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }} | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: true | |
- name: Install vcpkg | |
run: | | |
git clone https://github.com/microsoft/vcpkg.git | |
cd vcpkg && ./bootstrap-vcpkg.sh | |
echo "VCPKG_ROOT=${{github.workspace}}/vcpkg" >> $GITHUB_ENV | |
echo "${{github.workspace}}/vcpkg" >> $GITHUB_PATH | |
./vcpkg integrate install | |
shell: bash | |
- name: Build | |
run: | | |
cmake --preset=default -DVCPKG_TARGET_TRIPLET=${{matrix.vcpkg_triplet}} -B ${{github.workspace}}/build -DCMAKE_BUILD_TYPE=Release | |
cmake --build ${{github.workspace}}/build --config Release | |
- name: Test # don't release if tests are failing | |
working-directory: ${{github.workspace}}/build | |
run: ctest -C Release -L anyplatform --output-on-failure | |
- name: Package | |
run: | | |
cmake --preset=default -DVCPKG_TARGET_TRIPLET=${{matrix.vcpkg_triplet}} -B ${{github.workspace}}/pack -DCMAKE_BUILD_TYPE=Release -DBUILD_TESTING=OFF | |
cmake --build ${{github.workspace}}/pack --config Release | |
cpack --config ${{github.workspace}}/pack/CPackConfig.cmake -C Release -G ZIP | |
- uses: actions/upload-artifact@v4 | |
with: | |
name: ${{matrix.platform}} binaries | |
path: ${{github.workspace}}/*.zip | |
mac-build: | |
name: Build on macos-latest | |
runs-on: "macos-latest" | |
permissions: | |
actions: write | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }}-${{ matrix.platform }} | |
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }} | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: true | |
- name: Install vcpkg | |
run: | | |
git clone https://github.com/microsoft/vcpkg.git | |
cd vcpkg && ./bootstrap-vcpkg.sh | |
echo "VCPKG_ROOT=${{github.workspace}}/vcpkg" >> $GITHUB_ENV | |
echo "${{github.workspace}}/vcpkg" >> $GITHUB_PATH | |
./vcpkg integrate install | |
shell: bash | |
- name: Build for x64 | |
run: | | |
cmake --preset=default -DVCPKG_TARGET_TRIPLET=x64-osx -DVCPKG_INSTALLED_DIR=${{github.workspace}}/vcpkg-x64 -B ${{github.workspace}}/build-x64 -DCMAKE_BUILD_TYPE=Release -DCMAKE_OSX_ARCHITECTURES="x86_64" -DBUILD_TESTING=OFF | |
cmake --build ${{github.workspace}}/build-x64 --config Release | |
- name: Build for arm64 | |
run: | | |
cmake --preset=default -DVCPKG_TARGET_TRIPLET=arm64-osx -DVCPKG_INSTALLED_DIR=${{github.workspace}}/vcpkg-arm64 -B ${{github.workspace}}/build-arm64 -DCMAKE_BUILD_TYPE=Release -DCMAKE_OSX_ARCHITECTURES="arm64" -DBUILD_TESTING=OFF | |
cmake --build ${{github.workspace}}/build-arm64 --config Release | |
- name: Test # don't release if tests are failing | |
working-directory: ${{github.workspace}}/build-arm64 | |
run: ctest -C Release -L anyplatform --output-on-failure | |
- name: Create a universal binary | |
run: | | |
cp -r ${{github.workspace}}/build-x64 ${{github.workspace}}/build && cd ${{github.workspace}}/build | |
for filename in $(find . -type f -exec grep -H "build-x64" {} \; | awk '{print $1}' | sed -e 's/:.*//' | sort -u); do sed -i.bak -e "s/build-x64/build/g" $filename && rm ${filename}.bak; done | |
for lib in `find . -type f \( -name "*.so" -o -name "*.a" \)`; do rm $lib && lipo -create ../build-x64/${lib} ../build-arm64/${lib} -output $lib; done | |
- name: Package | |
run: | | |
cpack --config ${{github.workspace}}/build/CPackConfig.cmake -C Release -G ZIP | |
- uses: actions/upload-artifact@v4 | |
with: | |
name: macos-latest binaries | |
path: ${{github.workspace}}/*.zip | |
build-wheel: | |
strategy: | |
matrix: | |
platform: | |
- "windows-latest" | |
- "ubuntu-22.04" | |
- "macos-latest" # TODO (aliddell): universal binary? | |
runs-on: ${{ matrix.platform }} | |
permissions: | |
actions: write | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }}-${{ matrix.platform }}-build-wheel | |
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }} | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: true | |
- name: Set up Python | |
uses: actions/setup-python@v4 | |
with: | |
python-version: "3.10" | |
- name: Install vcpkg | |
run: | | |
git clone https://github.com/microsoft/vcpkg.git | |
cd vcpkg && ./bootstrap-vcpkg.sh | |
echo "VCPKG_ROOT=${{github.workspace}}/vcpkg" >> $GITHUB_ENV | |
echo "${{github.workspace}}/vcpkg" >> $GITHUB_PATH | |
./vcpkg integrate install | |
shell: bash | |
- name: Install system dependencies | |
if: ${{ matrix.platform == 'ubuntu-22.04' }} | |
run: | | |
sudo apt-get install patchelf | |
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-11 90 | |
sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-11 90 | |
- name: Install Python dependencies | |
run: python -m pip install -U pip "pybind11[global]" cmake build numpy pytest auditwheel | |
- name: Install | |
run: python -m pip install ".[testing]" | |
- name: Test | |
run: python -m pytest -v | |
- name: Build | |
run: python -m build -o dist | |
- name: Fix wheel for manylinux | |
if: ${{ matrix.platform == 'ubuntu-22.04' }} | |
run: | | |
auditwheel repair dist/*.whl -w dist --plat manylinux_2_35_x86_64 | |
rm dist/*-linux_*.whl | |
- name: Upload wheel | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ${{matrix.platform}} wheel | |
path: ${{github.workspace}}/dist/*.whl | |
release: | |
needs: | |
- windows-and-linux-build | |
- mac-build | |
- build-wheel | |
name: "Release" | |
runs-on: "ubuntu-latest" | |
environment: | |
name: pypi | |
url: https://pypi.org/p/acquire-zarr | |
permissions: write-all | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/download-artifact@v4 | |
id: download | |
with: | |
path: ${{ github.workspace }}/artifacts | |
- name: Collect wheels | |
run: | | |
mkdir -p dist | |
mv ${{steps.download.outputs.download-path}}/*/*.whl dist | |
- name: Tagged release | |
if: ${{ github.ref_name != 'nightly' }} | |
uses: marvinpinto/action-automatic-releases@latest | |
with: | |
repo_token: ${{ github.token }} | |
prerelease: false | |
files: | | |
${{steps.download.outputs.download-path}}/*/*.zip | |
dist/*.whl | |
- name: Nightly release | |
if: ${{ github.ref_name == 'nightly' }} | |
uses: marvinpinto/action-automatic-releases@latest | |
with: | |
repo_token: ${{ secrets.PAT }} | |
automatic_release_tag: "nightly" | |
prerelease: true | |
title: "Nightly Release" | |
files: | | |
${{steps.download.outputs.download-path}}/*/*.zip | |
dist/*.whl | |
- name: Publish wheels | |
if: ${{ github.ref_name != 'nightly' }} | |
uses: pypa/gh-action-pypi-publish@release/v1 | |
with: | |
skip-existing: true |