feat(torii-indexer): task manager & parallelize erc transfers #1394
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: | |
workflow_dispatch: | |
pull_request: | |
types: [closed] | |
branches: | |
- main | |
env: | |
CARGO_TERM_COLOR: always | |
RUST_VERSION: 1.80.0 | |
REGISTRY_IMAGE: ghcr.io/${{ github.repository }} | |
jobs: | |
prepare: | |
if: (github.event.pull_request.merged == true && github.event.pull_request.head.ref == 'prepare-release') || github.event_name == 'workflow_dispatch' | |
runs-on: ubuntu-latest | |
outputs: | |
tag_name: ${{ steps.release_info.outputs.tag_name }} | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Get version | |
id: release_info | |
run: | | |
cargo install cargo-get | |
echo "tag_name=$(cargo get workspace.package.version)" >> $GITHUB_OUTPUT | |
release: | |
name: ${{ matrix.job.target }} (${{ matrix.job.os }}) | |
needs: prepare | |
runs-on: ${{ matrix.job.os }} | |
env: | |
PLATFORM_NAME: ${{ matrix.job.platform }} | |
TARGET: ${{ matrix.job.target }} | |
ARCH: ${{ matrix.job.arch }} | |
strategy: | |
matrix: | |
job: | |
# The OS is used for the runner | |
# The platform is a generic platform name | |
# The target is used by Cargo | |
# The arch is either 386, arm64 or amd64 | |
# The svm target platform to use for the binary https://github.com/roynalnaruto/svm-rs/blob/84cbe0ac705becabdc13168bae28a45ad2299749/svm-builds/build.rs#L4-L24 | |
- os: ubuntu-latest-8-cores | |
platform: linux | |
target: x86_64-unknown-linux-gnu | |
arch: amd64 | |
- os: ubuntu-latest-8-cores-arm64 | |
platform: linux | |
target: aarch64-unknown-linux-gnu | |
arch: arm64 | |
svm_target_platform: linux-aarch64 | |
- os: macos-latest-xlarge | |
platform: darwin | |
target: x86_64-apple-darwin | |
arch: amd64 | |
- os: macos-latest | |
platform: darwin | |
target: aarch64-apple-darwin | |
arch: arm64 | |
- os: windows-latest | |
platform: win32 | |
target: x86_64-pc-windows-msvc | |
arch: amd64 | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: dtolnay/rust-toolchain@master | |
name: Rust Toolchain Setup | |
with: | |
targets: ${{ matrix.job.target }} | |
toolchain: ${{ env.RUST_VERSION }} | |
- uses: Swatinem/rust-cache@v1 | |
with: | |
cache-on-failure: true | |
# required for `aws-lc-rs` crate to compile on Windows; https://aws.github.io/aws-lc-rs/requirements/windows.html | |
- name: Install NASM | |
uses: ilammy/setup-nasm@v1 | |
with: | |
version: "2.15.05" | |
- uses: arduino/setup-protoc@v2 | |
with: | |
repo-token: ${{ secrets.GITHUB_TOKEN }} | |
version: "25.x" | |
- name: Apple M1 setup | |
if: ${{ matrix.job.target == 'aarch64-apple-darwin' }} | |
run: | | |
echo "SDKROOT=$(xcrun -sdk macosx --show-sdk-path)" >> $GITHUB_ENV | |
echo "MACOSX_DEPLOYMENT_TARGET=$(xcrun -sdk macosx --show-sdk-platform-version)" >> $GITHUB_ENV | |
- name: Linux ARM setup | |
if: ${{ matrix.job.target == 'aarch64-unknown-linux-gnu' }} | |
run: | | |
sudo apt-get update -y | |
sudo apt-get install -y gcc-aarch64-linux-gnu libssl-dev | |
# We build jemalloc with 64KB pagesize so that it works for all linux/arm64 pagesize variants | |
# See: https://github.com/jemalloc/jemalloc/issues/467 | |
echo "JEMALLOC_SYS_WITH_LG_PAGE=16" >> $GITHUB_ENV | |
- name: Build binaries | |
run: cargo build --release --bins --target ${{ matrix.job.target }} | |
- name: Archive binaries | |
id: artifacts | |
env: | |
VERSION_NAME: v${{ needs.prepare.outputs.tag_name }} | |
run: | | |
if [ "$PLATFORM_NAME" == "linux" ]; then | |
tar -czvf "dojo_${VERSION_NAME}_${PLATFORM_NAME}_${ARCH}.tar.gz" -C ./target/${TARGET}/release katana sozo torii dojo-language-server | |
echo "file_name=dojo_${VERSION_NAME}_${PLATFORM_NAME}_${ARCH}.tar.gz" >> $GITHUB_OUTPUT | |
elif [ "$PLATFORM_NAME" == "darwin" ]; then | |
# We need to use gtar here otherwise the archive is corrupt. | |
# See: https://github.com/actions/virtual-environments/issues/2619 | |
gtar -czvf "dojo_${VERSION_NAME}_${PLATFORM_NAME}_${ARCH}.tar.gz" -C ./target/${TARGET}/release katana sozo torii dojo-language-server | |
echo "file_name=dojo_${VERSION_NAME}_${PLATFORM_NAME}_${ARCH}.tar.gz" >> $GITHUB_OUTPUT | |
else | |
cd ./target/${TARGET}/release | |
7z a -tzip "dojo_${VERSION_NAME}_${PLATFORM_NAME}_${ARCH}.zip" katana.exe sozo.exe torii.exe dojo-language-server.exe | |
mv "dojo_${VERSION_NAME}_${PLATFORM_NAME}_${ARCH}.zip" ../../../ | |
echo "file_name=dojo_${VERSION_NAME}_${PLATFORM_NAME}_${ARCH}.tar.gz" >> $GITHUB_OUTPUT | |
fi | |
shell: bash | |
# We move binaries so they match $TARGETPLATFORM in the Docker build | |
- name: Move Binaries | |
if: ${{ env.PLATFORM_NAME == 'linux' }} | |
run: | | |
mkdir -p $PLATFORM_NAME/$ARCH | |
mv target/$TARGET/release/katana $PLATFORM_NAME/$ARCH | |
mv target/$TARGET/release/sozo $PLATFORM_NAME/$ARCH | |
mv target/$TARGET/release/torii $PLATFORM_NAME/$ARCH | |
shell: bash | |
# Upload these for use with the Docker build later | |
- name: Upload docker binaries | |
uses: actions/upload-artifact@v3 | |
with: | |
name: binaries | |
path: ${{ env.PLATFORM_NAME }} | |
retention-days: 1 | |
- name: Upload release artifacts | |
uses: actions/upload-artifact@v3 | |
with: | |
name: artifacts | |
path: ${{ steps.artifacts.outputs.file_name }} | |
retention-days: 1 | |
create-draft-release: | |
runs-on: ubuntu-20.04-4-cores | |
needs: [prepare, release] | |
env: | |
GITHUB_USER: ${{ github.repository_owner }} | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
steps: | |
- uses: actions/checkout@v2 | |
- uses: actions/download-artifact@v3 | |
with: | |
name: artifacts | |
path: artifacts | |
- id: version_info | |
run: | | |
cargo install cargo-get | |
echo "version=$(cargo get workspace.package.version)" >> $GITHUB_OUTPUT | |
- name: Display structure of downloaded files | |
run: ls -R artifacts | |
- run: gh release create v${{ steps.version_info.outputs.version }} ./artifacts/*.gz --generate-notes --draft | |
docker-build-and-push: | |
runs-on: ubuntu-20.04-4-cores | |
needs: [prepare, release] | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v2 | |
- name: Download binaries | |
uses: actions/download-artifact@v3 | |
with: | |
name: binaries | |
path: artifacts/linux | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v1 | |
- name: Login to GitHub Container Registry | |
uses: docker/login-action@v1 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build and push docker image | |
uses: docker/build-push-action@v3 | |
with: | |
push: true | |
tags: ghcr.io/${{ github.repository }}:latest,ghcr.io/${{ github.repository }}:v${{ needs.prepare.outputs.tag_name }} | |
platforms: linux/amd64,linux/arm64 | |
build-contexts: | | |
artifacts=artifacts |