2ad475ceef
Zombienet tests are upstream Polkadot SDK tests with no custom pallet coverage. Mainnet has 500K+ blocks, 9 successful upgrades, and zero breakage — these tests provide no value for our project. Removed 22 files (2293 lines): - 6 workflow files (zombienet_*.yml, preflight, flaky-tests check) - 3 custom actions (zombienet, zombienet-sdk, download-binaries) - 5 scripts (dispatch, run, parse, process-logs, check-flaky) - 5 config files (zombienet-env, flaky-tests, test definitions) - 1 doc file (ZOMBIENET_CI.md) - Remaining comment references in build-publish-images.yml
577 lines
22 KiB
YAML
577 lines
22 KiB
YAML
# GHA for build-*
|
|
name: Build and push images
|
|
|
|
on:
|
|
push:
|
|
branches:
|
|
- main
|
|
pull_request:
|
|
types: [opened, synchronize, reopened, ready_for_review]
|
|
merge_group:
|
|
concurrency:
|
|
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
permissions: read-all
|
|
|
|
env:
|
|
COMMIT_SHA: ${{ github.event.pull_request.head.sha || github.sha }}
|
|
# Disable Parity's forklift GCS cache wrapper - we don't have GCP credentials on our VPS runners
|
|
RUSTC_WRAPPER: ""
|
|
|
|
jobs:
|
|
#
|
|
#
|
|
#
|
|
isdraft:
|
|
uses: ./.github/workflows/reusable-isdraft.yml
|
|
preflight:
|
|
needs: isdraft
|
|
uses: ./.github/workflows/reusable-preflight.yml
|
|
|
|
### Build ########################
|
|
|
|
#
|
|
#
|
|
#
|
|
build-linux-stable:
|
|
needs: [preflight]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER }}
|
|
timeout-minutes: 180
|
|
container:
|
|
image: ${{ needs.preflight.outputs.IMAGE }}
|
|
env:
|
|
RUST_TOOLCHAIN: stable
|
|
# Enable debug assertions since we are running optimized builds for testing
|
|
# but still want to have debug assertions.
|
|
RUSTFLAGS: "-Cdebug-assertions=y -Dwarnings"
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
- name: Configure git safe.directory
|
|
run: git config --global --add safe.directory '*'
|
|
- name: Disable forklift cache wrapper
|
|
run: echo "RUSTC_WRAPPER=" >> $GITHUB_ENV
|
|
- name: Install wasm32v1-none target
|
|
run: rustup target add wasm32v1-none
|
|
- name: build
|
|
id: required
|
|
run: |
|
|
cargo build --locked --profile testnet --features pyroscope,fast-runtime --bin pezkuwi --bin pezkuwi-prepare-worker --bin pezkuwi-execute-worker
|
|
PEZKUWICHAIN_EPOCH_DURATION=10 ./pezkuwi/scripts/build-only-wasm.sh pezkuwichain-runtime $(pwd)/runtimes/pezkuwichain-runtime-10/
|
|
PEZKUWICHAIN_EPOCH_DURATION=100 ./pezkuwi/scripts/build-only-wasm.sh pezkuwichain-runtime $(pwd)/runtimes/pezkuwichain-runtime-100/
|
|
PEZKUWICHAIN_EPOCH_DURATION=600 ./pezkuwi/scripts/build-only-wasm.sh pezkuwichain-runtime $(pwd)/runtimes/pezkuwichain-runtime-600/
|
|
pwd
|
|
ls -alR runtimes
|
|
- name: pack artifacts
|
|
run: |
|
|
mkdir -p ./artifacts
|
|
VERSION="${{ needs.preflight.outputs.SOURCE_REF_SLUG }}" # will be tag or branch name
|
|
mv ./target/testnet/pezkuwi ./artifacts/.
|
|
mv ./target/testnet/pezkuwi-prepare-worker ./artifacts/.
|
|
mv ./target/testnet/pezkuwi-execute-worker ./artifacts/.
|
|
mv ./runtimes/ ./artifacts/.
|
|
cd artifacts/
|
|
sha256sum pezkuwi | tee pezkuwi.sha256
|
|
shasum -c pezkuwi.sha256
|
|
cd ../
|
|
EXTRATAG="${{ needs.preflight.outputs.SOURCE_REF_SLUG }}-${COMMIT_SHA}"
|
|
echo "Pezkuwi version = ${VERSION} (EXTRATAG = ${EXTRATAG})"
|
|
echo -n ${VERSION} > ./artifacts/VERSION
|
|
echo -n ${EXTRATAG} > ./artifacts/EXTRATAG
|
|
echo -n ${GITHUB_RUN_ID} > ./artifacts/BUILD_LINUX_JOB_ID
|
|
RELEASE_VERSION=$(./artifacts/pezkuwi -V | awk '{print $2}'| awk -F "-" '{print $1}')
|
|
echo -n "v${RELEASE_VERSION}" > ./artifacts/BUILD_RELEASE_VERSION
|
|
cp -r docker/* ./artifacts
|
|
|
|
- name: tar
|
|
run: tar -cvf artifacts.tar artifacts
|
|
|
|
- name: upload artifacts
|
|
uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
with:
|
|
name: ${{ github.job }}-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
path: artifacts.tar
|
|
retention-days: 1
|
|
#
|
|
#
|
|
#
|
|
build-linux-stable-pezcumulus:
|
|
needs: [preflight]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER }}
|
|
timeout-minutes: 180
|
|
container:
|
|
image: ${{ needs.preflight.outputs.IMAGE }}
|
|
env:
|
|
RUSTFLAGS: "-Cdebug-assertions=y -Dwarnings"
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
- name: Disable forklift cache wrapper
|
|
run: echo "RUSTC_WRAPPER=" >> $GITHUB_ENV
|
|
- name: Install wasm32v1-none target
|
|
run: rustup target add wasm32v1-none
|
|
- name: build
|
|
id: required
|
|
run: |
|
|
echo "___Building a binary, please refrain from using it in production since it goes with the debug assertions.___"
|
|
cargo build --release --locked -p pezkuwi-teyrchain-bin --bin pezkuwi-teyrchain
|
|
echo "___Packing the artifacts___"
|
|
mkdir -p ./artifacts
|
|
mv ./target/release/pezkuwi-teyrchain ./artifacts/.
|
|
echo "___The VERSION is either a tag name or the curent branch if triggered not by a tag___"
|
|
echo ${{ needs.preflight.outputs.SOURCE_REF_SLUG }} | tee ./artifacts/VERSION
|
|
|
|
- name: tar
|
|
run: tar -cvf artifacts.tar artifacts
|
|
|
|
- name: upload artifacts
|
|
uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
with:
|
|
name: ${{ github.job }}-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
path: artifacts.tar
|
|
retention-days: 1
|
|
#
|
|
#
|
|
#
|
|
build-test-teyrchain:
|
|
needs: [preflight]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER }}
|
|
timeout-minutes: 180
|
|
container:
|
|
image: ${{ needs.preflight.outputs.IMAGE }}
|
|
env:
|
|
RUSTFLAGS: "-Cdebug-assertions=y -Dwarnings"
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
- name: Disable forklift cache wrapper
|
|
run: echo "RUSTC_WRAPPER=" >> $GITHUB_ENV
|
|
- name: Install wasm32v1-none target
|
|
run: rustup target add wasm32v1-none
|
|
- name: build
|
|
id: required
|
|
run: |
|
|
echo "___Building a binary, please refrain from using it in production since it goes with the debug assertions.___"
|
|
cargo build --release --locked -p pezcumulus-test-service --bin test-teyrchain
|
|
- name: pack artifacts
|
|
run: |
|
|
echo "___Packing the artifacts___"
|
|
mkdir -p ./artifacts
|
|
mv ./target/release/test-teyrchain ./artifacts/.
|
|
mkdir -p ./artifacts/zombienet
|
|
mv ./target/release/wbuild/pezcumulus-test-runtime/wasm_binary_spec_version_incremented.rs.compact.compressed.wasm ./artifacts/zombienet/.
|
|
mv ./target/release/wbuild/pezcumulus-test-runtime/wasm_binary_elastic_scaling.rs.compact.compressed.wasm ./artifacts/zombienet/.
|
|
mv ./target/release/wbuild/pezcumulus-test-runtime/wasm_binary_elastic_scaling_12s_slot.rs.compact.compressed.wasm ./artifacts/zombienet/.
|
|
|
|
- name: tar
|
|
run: tar -cvf artifacts.tar artifacts
|
|
|
|
- name: upload artifacts
|
|
uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
with:
|
|
name: ${{ github.job }}-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
path: artifacts.tar
|
|
retention-days: 1
|
|
#
|
|
#
|
|
#
|
|
build-test-collators:
|
|
needs: [preflight]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER }}
|
|
timeout-minutes: 180
|
|
container:
|
|
image: ${{ needs.preflight.outputs.IMAGE }}
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
- name: Disable forklift cache wrapper
|
|
run: echo "RUSTC_WRAPPER=" >> $GITHUB_ENV
|
|
- name: Install wasm32v1-none target
|
|
run: rustup target add wasm32v1-none
|
|
- name: build
|
|
id: required
|
|
run: |
|
|
cargo build --locked --profile testnet -p test-teyrchain-adder-collator
|
|
cargo build --locked --profile testnet -p test-teyrchain-undying-collator
|
|
- name: pack artifacts
|
|
run: |
|
|
mkdir -p ./artifacts
|
|
mv ./target/testnet/adder-collator ./artifacts/.
|
|
mv ./target/testnet/undying-collator ./artifacts/.
|
|
echo -n "${{ needs.preflight.outputs.SOURCE_REF_SLUG }}" > ./artifacts/VERSION
|
|
echo -n "${{ needs.preflight.outputs.SOURCE_REF_SLUG }}-${COMMIT_SHA}" > ./artifacts/EXTRATAG
|
|
echo "adder-collator version = $(cat ./artifacts/VERSION) (EXTRATAG = $(cat ./artifacts/EXTRATAG))"
|
|
echo "undying-collator version = $(cat ./artifacts/VERSION) (EXTRATAG = $(cat ./artifacts/EXTRATAG))"
|
|
cp -r ./docker/* ./artifacts
|
|
|
|
- name: tar
|
|
run: tar -cvf artifacts.tar artifacts
|
|
|
|
- name: upload artifacts
|
|
uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
with:
|
|
name: ${{ github.job }}-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
path: artifacts.tar
|
|
retention-days: 1
|
|
#
|
|
#
|
|
#
|
|
build-malus:
|
|
needs: [preflight]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER }}
|
|
timeout-minutes: 180
|
|
container:
|
|
image: ${{ needs.preflight.outputs.IMAGE }}
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
- name: Disable forklift cache wrapper
|
|
run: echo "RUSTC_WRAPPER=" >> $GITHUB_ENV
|
|
- name: Install wasm32v1-none target
|
|
run: rustup target add wasm32v1-none
|
|
- name: build
|
|
id: required
|
|
run: |
|
|
cargo build --locked --profile testnet -p pezkuwi-test-malus --bin malus --bin pezkuwi-prepare-worker --bin pezkuwi-execute-worker
|
|
- name: pack artifacts
|
|
run: |
|
|
mkdir -p ./artifacts
|
|
mv ./target/testnet/malus ./artifacts/.
|
|
mv ./target/testnet/pezkuwi-execute-worker ./artifacts/.
|
|
mv ./target/testnet/pezkuwi-prepare-worker ./artifacts/.
|
|
echo -n "${{ needs.preflight.outputs.SOURCE_REF_SLUG }}" > ./artifacts/VERSION
|
|
echo -n "${{ needs.preflight.outputs.SOURCE_REF_SLUG }}-${COMMIT_SHA}" > ./artifacts/EXTRATAG
|
|
echo "pezkuwi-test-malus = $(cat ./artifacts/VERSION) (EXTRATAG = $(cat ./artifacts/EXTRATAG))"
|
|
cp -r ./docker/* ./artifacts
|
|
|
|
- name: tar
|
|
run: tar -cvf artifacts.tar artifacts
|
|
|
|
- name: upload artifacts
|
|
uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
with:
|
|
name: ${{ github.job }}-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
path: artifacts.tar
|
|
retention-days: 1
|
|
#
|
|
#
|
|
#
|
|
build-linux-bizinikiwi:
|
|
needs: [preflight]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER }}
|
|
timeout-minutes: 180
|
|
container:
|
|
image: ${{ needs.preflight.outputs.IMAGE }}
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
- name: Configure git safe.directory
|
|
run: git config --global --add safe.directory '*'
|
|
- name: Disable forklift cache wrapper
|
|
run: echo "RUSTC_WRAPPER=" >> $GITHUB_ENV
|
|
- name: Install wasm32v1-none target
|
|
run: rustup target add wasm32v1-none
|
|
- name: build
|
|
id: required
|
|
run: |
|
|
mkdir -p ./artifacts/bizinikiwi/
|
|
WASM_BUILD_NO_COLOR=1 cargo build --locked --release -p pezstaging-node-cli
|
|
ls -la target/release/
|
|
- name: pack artifacts
|
|
shell: bash
|
|
run: |
|
|
mv target/release/bizinikiwi-node ./artifacts/bizinikiwi/bizinikiwi
|
|
echo -n "Bizinikiwi version = "
|
|
if [[ "${{ github.ref }}" == "refs/tags/"* ]]; then
|
|
echo "${{ github.ref_name }}" | tee ./artifacts/bizinikiwi/VERSION;
|
|
else
|
|
./artifacts/bizinikiwi/bizinikiwi --version |
|
|
cut -d ' ' -f 2 | tee ./artifacts/bizinikiwi/VERSION;
|
|
fi
|
|
sha256sum ./artifacts/bizinikiwi/bizinikiwi | tee ./artifacts/bizinikiwi/bizinikiwi.sha256
|
|
cp -r ./docker/dockerfiles/bizinikiwi_injected.Dockerfile ./artifacts/bizinikiwi/
|
|
|
|
- name: tar
|
|
run: tar -cvf artifacts.tar artifacts
|
|
|
|
- name: upload artifacts
|
|
uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
with:
|
|
name: ${{ github.job }}-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
path: artifacts.tar
|
|
retention-days: 1
|
|
#
|
|
#
|
|
#
|
|
build-templates-node:
|
|
needs: [preflight]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER }}
|
|
timeout-minutes: 180
|
|
container:
|
|
image: ${{ needs.preflight.outputs.IMAGE }}
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
- name: Disable forklift cache wrapper
|
|
run: echo "RUSTC_WRAPPER=" >> $GITHUB_ENV
|
|
- name: Install wasm32v1-none target
|
|
run: rustup target add wasm32v1-none
|
|
- name: build
|
|
id: required
|
|
run: |
|
|
cargo build --locked --package teyrchain-template-node --release
|
|
cargo build --locked --package pez-minimal-template-node --release
|
|
cargo build --locked --package pez-solochain-template-node --release
|
|
- name: pack artifacts
|
|
run: |
|
|
mkdir -p ./artifacts
|
|
mv ./target/release/teyrchain-template-node ./artifacts/.
|
|
mv ./target/release/pez-minimal-template-node ./artifacts/.
|
|
mv ./target/release/pez-solochain-template-node ./artifacts/.
|
|
echo -n "${{ needs.preflight.outputs.SOURCE_REF_SLUG }}" > ./artifacts/VERSION
|
|
echo -n "${{ needs.preflight.outputs.SOURCE_REF_SLUG }}-${COMMIT_SHA}" > ./artifacts/EXTRATAG
|
|
echo "pezkuwi-test-malus = $(cat ./artifacts/VERSION) (EXTRATAG = $(cat ./artifacts/EXTRATAG))"
|
|
|
|
- name: tar
|
|
run: tar -cvf artifacts.tar artifacts
|
|
|
|
- name: upload artifacts
|
|
uses: actions/upload-artifact@bbbca2ddaa5d8feaa63e36b76fdaad77386f024f # v7.0.0
|
|
with:
|
|
name: ${{ github.job }}-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
path: artifacts.tar
|
|
retention-days: 1
|
|
|
|
|
|
### Publish ########################
|
|
|
|
#
|
|
#
|
|
#
|
|
build-push-image-test-teyrchain:
|
|
needs: [preflight, build-test-teyrchain]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER_DEFAULT }}
|
|
timeout-minutes: 180
|
|
steps:
|
|
- name: Fix workspace permissions
|
|
run: |
|
|
sudo chown -R "$(whoami)" "$GITHUB_WORKSPACE" || {
|
|
echo "::warning::sudo chown failed - attempting cleanup"
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/* 2>/dev/null || true
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/.[!.]* 2>/dev/null || true
|
|
}
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
|
|
- uses: actions/download-artifact@70fc10c6e5e1ce46ad2ea6f2b72d43f7d47b13c3 # v8.0.0
|
|
with:
|
|
name: build-test-teyrchain-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
|
|
- name: tar
|
|
run: tar -xvf artifacts.tar
|
|
|
|
- name: build and push image
|
|
uses: ./.github/actions/build-push-image
|
|
with:
|
|
image-name: "test-teyrchain"
|
|
dockerfile: "docker/dockerfiles/test-teyrchain_injected.Dockerfile"
|
|
username: ${{ secrets.PEZKUWI_DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.PEZKUWI_DOCKERHUB_PASSWORD }}
|
|
|
|
#
|
|
#
|
|
#
|
|
build-push-image-pezkuwi-debug:
|
|
needs: [preflight, build-linux-stable]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER_DEFAULT }}
|
|
timeout-minutes: 180
|
|
steps:
|
|
- name: Fix workspace permissions
|
|
run: |
|
|
sudo chown -R "$(whoami)" "$GITHUB_WORKSPACE" || {
|
|
echo "::warning::sudo chown failed - attempting cleanup"
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/* 2>/dev/null || true
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/.[!.]* 2>/dev/null || true
|
|
}
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
|
|
- uses: actions/download-artifact@70fc10c6e5e1ce46ad2ea6f2b72d43f7d47b13c3 # v8.0.0
|
|
with:
|
|
name: build-linux-stable-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
|
|
- name: tar
|
|
run: tar -xvf artifacts.tar
|
|
|
|
- name: build and push image
|
|
uses: ./.github/actions/build-push-image
|
|
with:
|
|
image-name: "pezkuwi-debug"
|
|
dockerfile: "docker/dockerfiles/pezkuwi/pezkuwi_injected_debug.Dockerfile"
|
|
username: ${{ secrets.PEZKUWI_DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.PEZKUWI_DOCKERHUB_PASSWORD }}
|
|
|
|
#
|
|
#
|
|
#
|
|
build-push-image-colander:
|
|
needs: [preflight, build-test-collators]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER_DEFAULT }}
|
|
timeout-minutes: 180
|
|
steps:
|
|
- name: Fix workspace permissions
|
|
run: |
|
|
sudo chown -R "$(whoami)" "$GITHUB_WORKSPACE" || {
|
|
echo "::warning::sudo chown failed - attempting cleanup"
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/* 2>/dev/null || true
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/.[!.]* 2>/dev/null || true
|
|
}
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
|
|
- uses: actions/download-artifact@70fc10c6e5e1ce46ad2ea6f2b72d43f7d47b13c3 # v8.0.0
|
|
with:
|
|
name: build-test-collators-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
|
|
- name: tar
|
|
run: tar -xvf artifacts.tar
|
|
|
|
- name: build and push image
|
|
uses: ./.github/actions/build-push-image
|
|
with:
|
|
image-name: "colander"
|
|
dockerfile: "docker/dockerfiles/collator_injected.Dockerfile"
|
|
username: ${{ secrets.PEZKUWI_DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.PEZKUWI_DOCKERHUB_PASSWORD }}
|
|
|
|
#
|
|
#
|
|
#
|
|
build-push-image-malus:
|
|
needs: [preflight, build-malus]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER_DEFAULT }}
|
|
timeout-minutes: 180
|
|
steps:
|
|
- name: Fix workspace permissions
|
|
run: |
|
|
sudo chown -R "$(whoami)" "$GITHUB_WORKSPACE" || {
|
|
echo "::warning::sudo chown failed - attempting cleanup"
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/* 2>/dev/null || true
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/.[!.]* 2>/dev/null || true
|
|
}
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
|
|
- uses: actions/download-artifact@70fc10c6e5e1ce46ad2ea6f2b72d43f7d47b13c3 # v8.0.0
|
|
with:
|
|
name: build-malus-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
|
|
- name: tar
|
|
run: tar -xvf artifacts.tar
|
|
|
|
- name: build and push image
|
|
uses: ./.github/actions/build-push-image
|
|
with:
|
|
image-name: "malus"
|
|
dockerfile: "docker/dockerfiles/malus_injected.Dockerfile"
|
|
username: ${{ secrets.PEZKUWI_DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.PEZKUWI_DOCKERHUB_PASSWORD }}
|
|
|
|
#
|
|
#
|
|
#
|
|
build-push-image-bizinikiwi-pr:
|
|
needs: [preflight, build-linux-bizinikiwi]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER_DEFAULT }}
|
|
timeout-minutes: 180
|
|
steps:
|
|
- name: Fix workspace permissions
|
|
run: |
|
|
sudo chown -R "$(whoami)" "$GITHUB_WORKSPACE" || {
|
|
echo "::warning::sudo chown failed - attempting cleanup"
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/* 2>/dev/null || true
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/.[!.]* 2>/dev/null || true
|
|
}
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
|
|
- uses: actions/download-artifact@70fc10c6e5e1ce46ad2ea6f2b72d43f7d47b13c3 # v8.0.0
|
|
with:
|
|
name: build-linux-bizinikiwi-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
|
|
- name: tar
|
|
run: tar -xvf artifacts.tar
|
|
|
|
- name: build and push image
|
|
uses: ./.github/actions/build-push-image
|
|
with:
|
|
image-name: "bizinikiwi"
|
|
dockerfile: "docker/dockerfiles/bizinikiwi_injected.Dockerfile"
|
|
username: ${{ secrets.PEZKUWI_DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.PEZKUWI_DOCKERHUB_PASSWORD }}
|
|
|
|
#
|
|
#
|
|
#
|
|
build-push-image-pezkuwi-teyrchain-debug:
|
|
needs: [preflight, build-linux-stable-pezcumulus]
|
|
runs-on: ${{ needs.preflight.outputs.RUNNER_DEFAULT }}
|
|
timeout-minutes: 180
|
|
steps:
|
|
- name: Fix workspace permissions
|
|
run: |
|
|
sudo chown -R "$(whoami)" "$GITHUB_WORKSPACE" || {
|
|
echo "::warning::sudo chown failed - attempting cleanup"
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/* 2>/dev/null || true
|
|
rm -rf "${GITHUB_WORKSPACE:?}"/.[!.]* 2>/dev/null || true
|
|
}
|
|
- name: Checkout
|
|
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
|
|
- uses: actions/download-artifact@70fc10c6e5e1ce46ad2ea6f2b72d43f7d47b13c3 # v8.0.0
|
|
with:
|
|
name: build-linux-stable-pezcumulus-${{ needs.preflight.outputs.SOURCE_REF_SLUG }}
|
|
|
|
- name: tar
|
|
run: tar -xvf artifacts.tar
|
|
|
|
- name: build and push image
|
|
uses: ./.github/actions/build-push-image
|
|
with:
|
|
image-name: "pezkuwi-teyrchain-debug"
|
|
dockerfile: "docker/dockerfiles/pezkuwi-teyrchain/pezkuwi-teyrchain-debug_unsigned_injected.Dockerfile"
|
|
username: ${{ secrets.PEZKUWI_DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.PEZKUWI_DOCKERHUB_PASSWORD }}
|
|
|
|
confirm-required-build-jobs-passed:
|
|
runs-on: ubuntu-latest
|
|
name: All builds passed
|
|
# If any new job gets added, be sure to add it to this array
|
|
needs:
|
|
- build-linux-stable
|
|
- build-linux-stable-pezcumulus
|
|
- build-test-teyrchain
|
|
- build-test-collators
|
|
- build-malus
|
|
- build-linux-bizinikiwi
|
|
- build-templates-node
|
|
if: always() && !cancelled()
|
|
outputs:
|
|
build_success: ${{ steps.check_success.outputs.build_success }}
|
|
steps:
|
|
- name: Check build success
|
|
id: check_success
|
|
run: |
|
|
tee resultfile <<< '${{ toJSON(needs) }}'
|
|
FAILURES=$(cat resultfile | grep '"result": "failure"' | wc -l)
|
|
if [ $FAILURES -gt 0 ]; then
|
|
echo "### At least one required job failed ❌" >> $GITHUB_STEP_SUMMARY
|
|
echo "build_success=false" >> $GITHUB_OUTPUT
|
|
exit 1
|
|
else
|
|
echo '### Good job! All the required jobs passed 🚀' >> $GITHUB_STEP_SUMMARY
|
|
echo "build_success=true" >> $GITHUB_OUTPUT
|
|
fi
|
|
|