mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-06 03:18:01 +00:00
0ff60f7da1
* Companion for removal of execution strategies https://github.com/paritytech/substrate/pull/14387 * Fix some tests * 🤦 * Adapt to latest changes * Start supporting the offchain transaction pool * Fix tests * FMT * Remove patches * Update Substrate * update lockfile for {"substrate"} * Fix parachain upgrade smoke test * Fix test * Rewrite all tests to use `MockSubstemClient` --------- Co-authored-by: parity-processbot <>
77 lines
2.1 KiB
Bash
Executable File
77 lines
2.1 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# Runs all benchmarks for all pallets, for a given runtime, provided by $1
|
|
# Should be run on a reference machine to gain accurate benchmarks
|
|
# current reference machine: https://github.com/paritytech/substrate/pull/5848
|
|
|
|
runtime="$1"
|
|
|
|
echo "[+] Compiling benchmarks..."
|
|
cargo build --profile production --locked --features=runtime-benchmarks
|
|
|
|
# Load all pallet names in an array.
|
|
PALLETS=($(
|
|
./target/production/polkadot benchmark pallet --list --chain="${runtime}-dev" |\
|
|
tail -n+2 |\
|
|
cut -d',' -f1 |\
|
|
sort |\
|
|
uniq
|
|
))
|
|
|
|
echo "[+] Benchmarking ${#PALLETS[@]} pallets for runtime $runtime"
|
|
|
|
# Define the error file.
|
|
ERR_FILE="benchmarking_errors.txt"
|
|
# Delete the error file before each run.
|
|
rm -f $ERR_FILE
|
|
|
|
# Benchmark each pallet.
|
|
for PALLET in "${PALLETS[@]}"; do
|
|
echo "[+] Benchmarking $PALLET for $runtime";
|
|
|
|
output_file=""
|
|
if [[ $PALLET == *"::"* ]]; then
|
|
# translates e.g. "pallet_foo::bar" to "pallet_foo_bar"
|
|
output_file="${PALLET//::/_}.rs"
|
|
fi
|
|
|
|
OUTPUT=$(
|
|
./target/production/polkadot benchmark pallet \
|
|
--chain="${runtime}-dev" \
|
|
--steps=50 \
|
|
--repeat=20 \
|
|
--pallet="$PALLET" \
|
|
--extrinsic="*" \
|
|
--wasm-execution=compiled \
|
|
--header=./file_header.txt \
|
|
--output="./runtime/${runtime}/src/weights/${output_file}" 2>&1
|
|
)
|
|
if [ $? -ne 0 ]; then
|
|
echo "$OUTPUT" >> "$ERR_FILE"
|
|
echo "[-] Failed to benchmark $PALLET. Error written to $ERR_FILE; continuing..."
|
|
fi
|
|
done
|
|
|
|
# Update the block and extrinsic overhead weights.
|
|
echo "[+] Benchmarking block and extrinsic overheads..."
|
|
OUTPUT=$(
|
|
./target/production/polkadot benchmark overhead \
|
|
--chain="${runtime}-dev" \
|
|
--wasm-execution=compiled \
|
|
--weight-path="runtime/${runtime}/constants/src/weights/" \
|
|
--warmup=10 \
|
|
--repeat=100 \
|
|
--header=./file_header.txt
|
|
)
|
|
if [ $? -ne 0 ]; then
|
|
echo "$OUTPUT" >> "$ERR_FILE"
|
|
echo "[-] Failed to benchmark the block and extrinsic overheads. Error written to $ERR_FILE; continuing..."
|
|
fi
|
|
|
|
# Check if the error file exists.
|
|
if [ -f "$ERR_FILE" ]; then
|
|
echo "[-] Some benchmarks failed. See: $ERR_FILE"
|
|
else
|
|
echo "[+] All benchmarks passed."
|
|
fi
|