Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

test: test runtime benchmarks #731

Merged
merged 13 commits into from
Sep 20, 2024
41 changes: 41 additions & 0 deletions .github/workflows/check-code.yml
Original file line number Diff line number Diff line change
Expand Up @@ -284,3 +284,44 @@ jobs:
--checks=all \
live \
--uri=wss://${{ matrix.runtime }}.kilt.io

test-runtime-benchmarks:
name: Test runtime benchmarks
runs-on: ubuntu-latest
needs: cargo-clippy
if: ${{ github.event_name == 'push'}}

strategy:
matrix:
runtime:
- peregrine
- spiritnet
fail-fast: false

steps:
- name: Checkout repository
uses: actions/checkout@v4

- name: Free Disk Space
uses: jlumbroso/free-disk-space@main
with:
tool-cache: true

- name: Set up Cargo cache
uses: actions/cache@v4
with:
path: |
~/.cargo/bin/
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
key: ${{ github.job }}-${{ github.ref }}-${{ matrix.runtime }}-${{ hashFiles('**/Cargo.lock') }}

- name: Run runtime benchmarks
run: |
docker run --rm \
-v "${GITHUB_WORKSPACE}:/workspace" \
-v "${HOME}/.cargo:/root/.cargo" \
-w /workspace \
paritytech/ci-unified:bullseye-1.74.0 \
bash -c "bash -x scripts/run_benches_for_runtime.sh ${{ matrix.runtime }} dev"
33 changes: 23 additions & 10 deletions scripts/run_benches_for_runtime.sh
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,11 @@
# current Substrate reference machine: https://github.com/paritytech/substrate/pull/5848

runtime=${1-"peregrine"}
profile=${2-"release"}

chain=$([ "$1" == "spiritnet" ] && echo "spiritnet-dev" || echo "dev")
standard_args="--release --locked --features=runtime-benchmarks --bin=kilt-parachain"
# Dev profile is the debug target
standard_args="--profile $2 --locked --features=runtime-benchmarks --bin=kilt-parachain"

pallets=(
pallet-migration
Expand Down Expand Up @@ -44,32 +47,42 @@ pallets=(
pallet-asset-switch
)



# Add Peregrine-only pallets here!
if [ "$runtime" = "peregrine" ]; then
pallets+=(
pallet-sudo
)
fi

echo "[+] Running all runtime benchmarks for $runtime --chain=$chain"
echo "[+] Running all runtime benchmarks for \"$runtime\", \"--chain=$chain\" and profile \"$profile\""

cargo build $standard_args

if [ $profile == "dev" ]; then
target_folder="debug"
# We care about benchmark correctness, not accuracy.
additional_args="--steps=2 --repeat=1 --default-pov-mode=ignored --no-verify"
else
target_folder=$profile
additional_args="--header=\"HEADER-GPL\" --template=\".maintain/runtime-weight-template.hbs\" --output=\"./runtimes/${runtime}/src/weights/\""
Ad96el marked this conversation as resolved.
Show resolved Hide resolved
fi

for pallet in "${pallets[@]}"; do
echo "Runtime: $runtime. Pallet: $pallet"
# shellcheck disable=SC2086
./target/release/kilt-parachain benchmark pallet \
--template=".maintain/runtime-weight-template.hbs" \
--header="HEADER-GPL" \
./target/$target_folder/kilt-parachain benchmark pallet \
--wasm-execution=compiled \
Ad96el marked this conversation as resolved.
Show resolved Hide resolved
--heap-pages=4096 \
--steps=50 \
--repeat=20 \
--chain="${chain}" \
--pallet="$pallet" \
--extrinsic="*" \
--output="./runtimes/${runtime}/src/weights/"
$additional_args

bench_status=$?

# Exit with error as soon as one benchmark fails
if [ $bench_status -ne 0 ]; then
exit $bench_status
fi

done
Loading