minor adjustments + test branch #216
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: Atomic Build and Release | |
on: | |
schedule: | |
# Run every Monday at 12:00 | |
- cron: 0 12 * * 1 | |
workflow_dispatch: | |
push: | |
tags: | |
- "*" | |
branches: | |
- tycho/release-atomically | |
env: | |
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} | |
SLACK_WEBHOOK_TYPE: INCOMING_WEBHOOK | |
concurrency: | |
group: release-${{ github.ref }} | |
cancel-in-progress: true | |
jobs: | |
atomic-release: | |
# This creates a node in the DAG so that all of the "push" tasks | |
# can depend on all build tasks. | |
name: Atomic Release | |
runs-on: ubuntu-latest | |
if: github.event_name == 'push' && startsWith(github.event.ref, 'refs/tags/v') | |
needs: | |
- python-linux | |
- python-macos | |
- python-windows | |
- kernel-dist | |
- node-build | |
steps: | |
- run: sleep 1 | |
######################################################################## | |
## | |
## Kernel Release | |
## | |
######################################################################## | |
kernel-dist: | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
- os: windows-latest-8-cores | |
target: x86_64-pc-windows-msvc | |
- os: ubuntu-2004-8-cores | |
target: x86_64-unknown-linux-gnu | |
- os: macos-12-large | |
target: x86_64-apple-darwin | |
- os: macos-13-xlarge | |
target: aarch64-apple-darwin | |
name: Build Kernel Release (${{ matrix.target }}) | |
runs-on: ${{ matrix.os }} | |
container: ${{ matrix.container }} | |
env: | |
DIST_TARGET_TRIPLE: ${{ matrix.target }} | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Rust toolchain | |
uses: dtolnay/[email protected] | |
with: | |
targets: ${{ matrix.target }} | |
- uses: extractions/setup-just@v1 | |
with: | |
just-version: "1.23.0" | |
- name: Build | |
run: just dist | |
- name: Upload artifacts | |
uses: actions/upload-artifact@v3 | |
with: | |
name: dist-${{ matrix.target }} | |
path: ./target/dist/ | |
- name: Post to slack | |
uses: slackapi/[email protected] | |
if: ${{ always() }} | |
with: | |
payload: | | |
{ | |
"text": "Build Kernel Binary (${{ matrix.target }}): ${{ job.status }}\n${{ github.event.pull_request.html_url || github.event.head_commit.url }}" | |
} | |
docker-push: | |
name: Build and Push Docker Image | |
runs-on: ubuntu-latest-8-cores | |
needs: [atomic-release] | |
permissions: | |
id-token: write # required to use OIDC auth | |
contents: write # required to checkout code | |
env: | |
GCP_PROJECT_ID: glaredb-artifacts | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Authenticate to Google Cloud | |
uses: google-github-actions/auth@v2 | |
with: | |
credentials_json: ${{ secrets.GCP_SERVICE_ACCOUNT_JSON }} | |
- name: Setup gcloud | |
uses: google-github-actions/setup-gcloud@v2 | |
- run: gcloud auth configure-docker -q | |
- run: ./scripts/build-and-push-images.sh | |
# TODO: this should pull the binary that was built in kernel-dist. | |
kernel-push: | |
name: Push Kernel Release | |
runs-on: ubuntu-latest | |
needs: [atomic-release] | |
steps: | |
- uses: actions/download-artifact@v3 | |
with: | |
name: dist-aarch64-apple-darwin | |
path: dist | |
- uses: actions/download-artifact@v3 | |
with: | |
name: dist-x86_64-apple-darwin | |
path: dist | |
- uses: actions/download-artifact@v3 | |
with: | |
name: dist-x86_64-unknown-linux-gnu | |
path: dist | |
- uses: actions/download-artifact@v3 | |
with: | |
name: dist-x86_64-pc-windows-msvc | |
path: dist | |
- run: ls -al ./dist | |
- name: Upload artifacts | |
uses: actions/upload-artifact@v3 | |
with: | |
name: releases | |
path: ./dist | |
- name: Post to slack | |
uses: slackapi/[email protected] | |
if: ${{ always() }} | |
with: | |
payload: | | |
{ | |
"text": "Publish Kernal Binary: ${{ job.status }}\n${{ github.event.pull_request.html_url || github.event.head_commit.url }}" | |
} | |
######################################################################## | |
## | |
## Python Bindings | |
## | |
######################################################################## | |
python-linux: | |
name: Build Python Bindings (linux ${{ matrix.target }}) | |
runs-on: ubuntu-2004-8-cores | |
permissions: | |
contents: read | |
strategy: | |
fail-fast: true | |
matrix: | |
target: [x86_64] | |
env: | |
PYTHON_VERSION: "3.11" | |
MATURIN_VERSION: "1.4.0" | |
PROTOC: "${{ github.workspace }}/deps/protoc/bin/protoc" | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: extractions/setup-just@v1 | |
with: | |
just-version: "1.23.0" | |
- name: install protoc | |
run: just protoc | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ env.PYTHON_VERSION }} | |
- name: Build wheels | |
uses: PyO3/maturin-action@v1 | |
with: | |
manylinux: "auto" | |
docker-options: "--env PROTOC=${{ env.PROTOC }}" | |
target: ${{ matrix.target }} | |
args: --release --out dist -m bindings/python/Cargo.toml | |
- name: Upload wheels | |
uses: actions/upload-artifact@v3 | |
with: | |
name: wheels | |
path: dist | |
- name: Post to slack | |
uses: slackapi/[email protected] | |
if: ${{ always() }} | |
with: | |
payload: | | |
{ | |
"text": "Build Python Bindings (linux ${{ matrix.target }}): ${{ job.status }}\n${{ github.event.pull_request.html_url || github.event.head_commit.url }}" | |
} | |
python-windows: | |
name: Build Python Bindings (windows ${{ matrix.target }}) | |
runs-on: windows-latest-8-cores | |
permissions: | |
contents: read | |
strategy: | |
fail-fast: true | |
matrix: | |
target: [x64] | |
env: | |
PYTHON_VERSION: "3.11" | |
MATURIN_VERSION: "1.4.0" | |
PROTOC: "${{ github.workspace }}/deps/protoc/bin/protoc" | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: extractions/setup-just@v1 | |
with: | |
just-version: "1.23.0" | |
- name: install protoc | |
run: just protoc | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ env.PYTHON_VERSION }} | |
architecture: ${{ matrix.target }} | |
- name: Build wheels | |
uses: PyO3/maturin-action@v1 | |
with: | |
target: ${{ matrix.target }} | |
args: --release --out dist | |
working-directory: bindings/python | |
container: "off" | |
- name: Upload wheels | |
uses: actions/upload-artifact@v3 | |
with: | |
name: wheels | |
path: bindings/python/dist | |
- name: Post to slack | |
uses: slackapi/[email protected] | |
if: ${{ always() }} | |
with: | |
payload: | | |
{ | |
"text": "Build Python Bindings (windows ${{ matrix.target }}): ${{ job.status }}\n${{ github.event.pull_request.html_url || github.event.head_commit.url }}" | |
} | |
python-macos: | |
name: Build Python Bindings (macos ${{ matrix.config.target }}) | |
runs-on: ${{ matrix.config.runner }} | |
permissions: | |
contents: read | |
strategy: | |
fail-fast: true | |
matrix: | |
config: | |
- target: x86_64-apple-darwin | |
runner: macos-13-large | |
- target: aarch64-apple-darwin | |
runner: macos-13-xlarge | |
env: | |
PYTHON_VERSION: "3.11" | |
MATURIN_VERSION: "1.4.0" | |
PROTOC: "${{ github.workspace }}/deps/protoc/bin/protoc" | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: extractions/setup-just@v1 | |
with: | |
just-version: "1.23.0" | |
- name: install protoc | |
run: just protoc | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ env.PYTHON_VERSION }} | |
- name: Build wheels | |
uses: PyO3/maturin-action@v1 | |
with: | |
args: --release ${{ matrix.config.target }} --out dist | |
working-directory: bindings/python | |
container: "off" | |
- name: Upload wheels | |
uses: actions/upload-artifact@v3 | |
with: | |
name: wheels | |
path: bindings/python/dist | |
- name: Post to slack | |
uses: slackapi/[email protected] | |
if: ${{ always() }} | |
with: | |
payload: | | |
{ | |
"text": "Build Python Bindings (macos ${{ matrix.config.target }}): ${{ job.status }}\n${{ github.event.pull_request.html_url || github.event.head_commit.url }}" | |
} | |
python-push: | |
name: Push Python Bindings | |
if: github.event_name == 'push' && startsWith(github.event.ref, 'refs/tags/v') | |
runs-on: ubuntu-latest | |
needs: [atomic-release] | |
permissions: | |
contents: read | |
env: | |
PYTHON_VERSION: "3.11" | |
MATURIN_VERSION: "1.4.0" | |
MATURIN_PYPI_TOKEN: ${{ secrets.PYPI_API_TOKEN }} | |
MATURIN_USERNAME: "seanglaredb" | |
steps: | |
- uses: actions/download-artifact@v3 | |
with: | |
name: wheels | |
- name: Publish to PyPI | |
uses: PyO3/maturin-action@v1 | |
env: | |
MATURIN_PYPI_TOKEN: ${{ secrets.PYPI_API_TOKEN }} | |
with: | |
command: upload | |
args: --skip-existing * | |
- name: Post to slack | |
uses: slackapi/[email protected] | |
if: ${{ always() }} | |
with: | |
payload: | | |
{ | |
"text": "Push Python Bindings: ${{ job.status }}\n${{ github.event.pull_request.html_url || github.event.head_commit.url }}" | |
} | |
######################################################################## | |
## | |
## Node.js Release Process | |
## | |
######################################################################## | |
node-build: | |
permissions: | |
contents: write | |
id-token: write | |
strategy: | |
fail-fast: true | |
matrix: | |
settings: | |
- host: macos-12-xl | |
target: x86_64-apple-darwin | |
build: | | |
yarn build | |
strip -x *.node | |
- host: windows-latest-8-cores | |
build: yarn build | |
target: x86_64-pc-windows-msvc | |
- host: ubuntu-2004-8-cores | |
target: x86_64-unknown-linux-gnu | |
docker: ghcr.io/napi-rs/napi-rs/nodejs-rust:lts-debian | |
build: |- | |
set -eux && | |
curl -L https://github.com/protocolbuffers/protobuf/releases/download/v23.1/protoc-23.1-linux-x86_64.zip -o protoc.zip | |
mkdir -p deps && | |
unzip -o protoc.zip -d deps/protoc && | |
rm protoc.zip | |
export PROTOC="$PWD/deps/protoc/bin/protoc" && | |
cd bindings/nodejs && | |
yarn build --target x86_64-unknown-linux-gnu && | |
strip *.node | |
- host: macos-12-xl | |
target: aarch64-apple-darwin | |
build: | | |
rustup target add aarch64-apple-darwin | |
sudo rm -Rf /Library/Developer/CommandLineTools/SDKs/*; | |
export CC=$(xcrun -f clang); | |
export CXX=$(xcrun -f clang++); | |
SYSROOT=$(xcrun --sdk macosx --show-sdk-path); | |
export CFLAGS="-isysroot $SYSROOT -isystem $SYSROOT"; | |
yarn build --target aarch64-apple-darwin | |
strip -x *.node | |
name: Build Node.JS Bindings (stable - ${{ matrix.settings.target }} - node@18) | |
runs-on: ${{ matrix.settings.host }} | |
env: | |
DEBUG: napi:* | |
APP_NAME: "glaredb" | |
MACOSX_DEPLOYMENT_TARGET: "10.13" | |
PROTOC: "${{ github.workspace }}/deps/protoc/bin/protoc" | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: extractions/setup-just@v1 | |
with: | |
just-version: "1.23.0" | |
- run: just protoc | |
- name: Setup node | |
uses: actions/setup-node@v4 | |
if: ${{ !matrix.settings.docker }} | |
with: | |
node-version: 20 | |
check-latest: true | |
- name: Install | |
uses: dtolnay/rust-toolchain@stable | |
if: ${{ !matrix.settings.docker }} | |
with: | |
toolchain: stable | |
targets: ${{ matrix.settings.target }} | |
- name: Cache cargo | |
uses: actions/cache@v4 | |
with: | |
path: | | |
~/.cargo/registry/index/ | |
~/.cargo/registry/cache/ | |
~/.cargo/git/db/ | |
.cargo-cache | |
target/ | |
key: ${{ matrix.settings.target }}-cargo-${{ matrix.settings.host }} | |
- uses: goto-bus-stop/setup-zig@v2 | |
if: ${{ matrix.settings.target == 'armv7-unknown-linux-gnueabihf' }} | |
with: | |
version: 0.10.1 | |
- name: Setup toolchain | |
run: ${{ matrix.settings.setup }} | |
if: ${{ matrix.settings.setup }} | |
shell: bash | |
- name: Setup node x86 | |
if: matrix.settings.target == 'i686-pc-windows-msvc' | |
run: yarn config set supportedArchitectures.cpu "ia32" | |
shell: bash | |
- name: Install dependencies | |
run: yarn install --frozen-lockfile | |
- name: Setup node x86 | |
uses: actions/setup-node@v4 | |
if: matrix.settings.target == 'i686-pc-windows-msvc' | |
with: | |
node-version: 20 | |
check-latest: true | |
architecture: x86 | |
- name: Build in docker | |
uses: addnab/docker-run-action@v3 | |
if: ${{ matrix.settings.docker }} | |
with: | |
image: ${{ matrix.settings.docker }} | |
options: "--user 0:0 -v ${{ github.workspace }}/.cargo-cache/git/db:/usr/local/cargo/git/db -v ${{ github.workspace }}/.cargo/registry/cache:/usr/local/cargo/registry/cache -v ${{ github.workspace }}/.cargo/registry/index:/usr/local/cargo/registry/index -v ${{ github.workspace }}:/build -w /build" | |
run: ${{ matrix.settings.build }} | |
- name: Build | |
run: ${{ matrix.settings.build }} | |
if: ${{ !matrix.settings.docker }} | |
shell: bash | |
- name: Upload artifact | |
uses: actions/upload-artifact@v3 | |
with: | |
name: bindings-${{ matrix.settings.target }} | |
path: bindings/nodejs/${{ env.APP_NAME }}.*.node | |
if-no-files-found: error | |
- name: Post to slack | |
uses: slackapi/[email protected] | |
if: ${{ always() }} | |
with: | |
payload: | | |
{ | |
"text": "Build Node.JS Bindings (stable - ${{ matrix.settings.target }} - node@18): ${{ job.status }}\n${{ github.event.pull_request.html_url || github.event.head_commit.url }}" | |
} | |
node-push: | |
name: Push Node.js Bindings | |
if: github.event_name == 'push' && startsWith(github.event.ref, 'refs/tags/v') | |
runs-on: ubuntu-2004-8-cores | |
needs: [atomic-release] | |
env: | |
DEBUG: napi:* | |
APP_NAME: "glaredb" | |
MACOSX_DEPLOYMENT_TARGET: "10.13" | |
PROTOC: "${{ github.workspace }}/deps/protoc/bin/protoc" | |
permissions: | |
contents: write | |
id-token: write | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: extractions/setup-just@v1 | |
- run: just protoc | |
- name: Setup node | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 20 | |
check-latest: true | |
registry-url: "https://registry.npmjs.org" | |
- name: Install dependencies | |
run: yarn install --frozen-lockfile | |
- name: Download all artifacts | |
uses: actions/download-artifact@v3 | |
with: | |
path: bindings/nodejs/artifacts | |
- name: Move artifacts | |
run: yarn artifacts | |
- name: List packages | |
run: ls -R ./npm | |
shell: bash | |
- name: Publish | |
run: | | |
echo "//registry.npmjs.org/:_authToken=$NPM_TOKEN" >> ~/.npmrc | |
npm publish | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
NPM_TOKEN: ${{ secrets.NPM_TOKEN }} | |
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | |
- name: Post to slack | |
uses: slackapi/[email protected] | |
if: ${{ always() }} | |
with: | |
payload: | | |
{ | |
"text": "Push Node.js Bindings: ${{ job.status }}\n${{ github.event.pull_request.html_url || github.event.head_commit.url }}" | |
} |