updated nethermind, reth, besu #29
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: Test Run CLI | |
on: | |
workflow_dispatch: | |
inputs: | |
root_dir: | |
description: "Enter the root directory for benchmarks" | |
required: true | |
default: "/home/runner/work/" | |
date: | |
description: "Enter a date (optional, e.g. 20240101)" | |
required: false | |
default: "" | |
clients: | |
description: "Enter clients to use (e.g., [nethermind,geth,reth,erigon,besu])" | |
required: true | |
default: "[nethermind,geth,reth,erigon,besu]" | |
sizes: | |
description: "Enter sizes (e.g., [500,1000])" | |
required: false | |
default: "[5,10]" | |
repetitions: | |
description: "Enter the number of repetitions" | |
required: true | |
default: 1 | |
pull_request: | |
types: [opened, synchronize] | |
jobs: | |
setup-environment: | |
runs-on: ubuntu-latest | |
env: | |
ROOT_DIR: ${{ github.event.inputs.root_dir || '/home/runner/work/' }} | |
DATE: ${{ github.event.inputs.date || '' }} | |
CLIENTS: ${{ github.event.inputs.clients || '["nethermind","geth","reth","erigon","besu"]' }} | |
SIZES: ${{ github.event.inputs.sizes || '[5,10]' }} | |
REPETITIONS: ${{ github.event.inputs.repetitions || 1 }} | |
outputs: | |
date: ${{ steps.set-date.outputs.date }} | |
root_dir: ${{ steps.set-date.outputs.root_dir }} | |
clients: ${{ steps.set-date.outputs.clients }} | |
sizes: ${{ steps.set-date.outputs.sizes }} | |
repetitions: ${{ steps.set-date.outputs.repetitions }} | |
steps: | |
- name: Set DATE variable | |
id: set-date | |
run: | | |
if [ -z "${{ env.DATE }}" ]; then | |
DATE=$(date +%Y%m%d) | |
else | |
DATE=${{ env.DATE }} | |
fi | |
echo "date=${DATE}" >> $GITHUB_OUTPUT | |
echo "root_dir=${{ env.ROOT_DIR }}" >> $GITHUB_OUTPUT | |
echo "clients=${{ env.CLIENTS }}" >> $GITHUB_OUTPUT | |
echo "sizes=${{ env.SIZES }}" >> $GITHUB_OUTPUT | |
echo "repetitions=${{ env.REPETITIONS }}" >> $GITHUB_OUTPUT | |
generate-matrix: | |
runs-on: ubuntu-latest | |
needs: setup-environment | |
outputs: | |
matrix: ${{ steps.generate-matrix.outputs.matrix }} | |
date: ${{ needs.setup-environment.outputs.date }} | |
root_dir: ${{ needs.setup-environment.outputs.root_dir }} | |
clients: ${{ needs.setup-environment.outputs.clients }} | |
sizes: ${{ needs.setup-environment.outputs.sizes }} | |
repetitions: ${{ needs.setup-environment.outputs.repetitions }} | |
steps: | |
- name: Check Date | |
id: check-date | |
run: | | |
if [ -z "${{ needs.setup-environment.outputs.date }}" ];then | |
echo "Date is empty, exiting the job." | |
exit 1 | |
fi | |
- name: Generate Matrix | |
id: generate-matrix | |
run: | | |
CLIENTS='${{ needs.setup-environment.outputs.clients }}' | |
SIZES='${{ needs.setup-environment.outputs.sizes }}' | |
echo "CLIENTS=${CLIENTS}" | |
echo "SIZES=${SIZES}" | |
CLIENTS_JSON=$(echo "$CLIENTS" | sed 's/[][]//g' | jq -R 'split(",")') | |
SIZES_JSON=$(echo "$SIZES" | sed 's/[][]//g' | jq -R 'split(",") | map(tonumber)') | |
MATRIX_CLIENTS=$(echo '{}' | jq -c --argjson clients "$CLIENTS_JSON" '.Client = $clients') | |
MATRIX=$(echo $MATRIX_CLIENTS | jq -c --argjson sizes "$SIZES_JSON" '.Size = $sizes') | |
echo "Updated MATRIX=${MATRIX}" | |
echo "matrix=${MATRIX}" >> $GITHUB_OUTPUT | |
run-gas-benchmarks: | |
runs-on: ubuntu-latest | |
needs: generate-matrix | |
outputs: | |
matrix: ${{ needs.generate-matrix.outputs.matrix }} | |
date: ${{ needs.generate-matrix.outputs.date }} | |
root_dir: ${{ needs.generate-matrix.outputs.root_dir }} | |
clients: ${{ needs.generate-matrix.outputs.clients }} | |
sizes: ${{ needs.generate-matrix.outputs.sizes }} | |
repetitions: ${{ needs.generate-matrix.outputs.repetitions }} | |
strategy: | |
max-parallel: 8 | |
matrix: | |
client: ${{ fromJson(needs.generate-matrix.outputs.matrix).Client }} | |
fail-fast: false | |
steps: | |
- name: Increase swapfile | |
run: | | |
sudo swapoff -a | |
sudo fallocate -l 15G /swapfile | |
sudo chmod 600 /swapfile | |
sudo mkswap /swapfile | |
sudo swapon /swapfile | |
sudo swapon --show | |
- name: Clone gas benchmarks repo | |
run: | | |
ROOT_DIR=${{ needs.generate-matrix.outputs.root_dir }} | |
BRANCH_GAS_BENCHMARKS=rc-1 | |
mkdir -p "${ROOT_DIR}" | |
cd "${ROOT_DIR}" | |
git clone -b $BRANCH_GAS_BENCHMARKS https://github.com/OpenFusionist/gas-benchmarks.git gas-benchmarks | |
- name: Checkout PR branch of benchmarks-data-results | |
uses: actions/checkout@v3 | |
with: | |
repository: OpenFusionist/benchmarks-data-results | |
path: benchmarks-data-result | |
ref: ${{ github.event.pull_request.head.sha }} | |
- name: Copy images.yaml | |
run: | | |
ROOT_DIR=${{ needs.generate-matrix.outputs.root_dir }} | |
cp "${GITHUB_WORKSPACE}/benchmarks-data-result/images.yaml" "${ROOT_DIR}/gas-benchmarks/" | |
- name: Run gas benchmarks | |
run: | | |
CLIENT=${{ matrix.client }} | |
REPETITIONS=${{ needs.generate-matrix.outputs.repetitions }} | |
ROOT_DIR=${{ needs.generate-matrix.outputs.root_dir }} | |
DATE=${{ needs.generate-matrix.outputs.date }} | |
cd "$ROOT_DIR/gas-benchmarks" | |
./run.sh -t "tests/" -w "" -c "$CLIENT" -r "$REPETITIONS" -o "results-$DATE" | |
python3 report_metadata.py "$DATE" | |
sudo apt-get install -y jq | |
max_value=$(jq -r '.["'"${{ matrix.client }}"'"].GasLimit.max' "results-$DATE/reports/result.json") | |
if [ "$max_value" = "0" ] || [ -z "$max_value" ]; then | |
echo "Client '${{ matrix.client }}' has no valid data (max=0 or missing)." | |
exit 1 | |
else | |
echo "Client '${{ matrix.client }}' has valid data (max=$max_value)." | |
fi | |
- name: Zip the results folder | |
run: | | |
ROOT_DIR=${{ needs.generate-matrix.outputs.root_dir }} | |
DATE=${{ needs.generate-matrix.outputs.date }} | |
cd "$ROOT_DIR/gas-benchmarks" | |
zip -r reports-$DATE.zip "results-$DATE/reports" | |
- name: Upload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: gas-benchmarks-${{ matrix.client }}-${{ needs.generate-matrix.outputs.date }} | |
path: ${{ needs.generate-matrix.outputs.root_dir }}/gas-benchmarks/reports-${{ needs.generate-matrix.outputs.date }}.zip | |
run-genesis-init-speed-benchmarks: | |
runs-on: ubuntu-latest | |
needs: run-gas-benchmarks | |
outputs: | |
matrix: ${{ needs.run-gas-benchmarks.outputs.matrix }} | |
date: ${{ needs.run-gas-benchmarks.outputs.date }} | |
root_dir: ${{ needs.run-gas-benchmarks.outputs.root_dir }} | |
clients: ${{ needs.run-gas-benchmarks.outputs.clients }} | |
sizes: ${{ needs.run-gas-benchmarks.outputs.sizes }} | |
repetitions: ${{ needs.run-gas-benchmarks.outputs.repetitions }} | |
strategy: | |
max-parallel: 8 | |
matrix: | |
client: ${{ fromJson(needs.run-gas-benchmarks.outputs.matrix).Client }} | |
size: ${{ fromJson(needs.run-gas-benchmarks.outputs.matrix).Size }} | |
fail-fast: false | |
steps: | |
- name: Clone genesis init benchmarks repo | |
run: | | |
ROOT_DIR=${{ needs.run-gas-benchmarks.outputs.root_dir }} | |
BRANCH_GENESIS_INIT_BENCHMARKS=main | |
mkdir -p "${ROOT_DIR}" | |
cd "${ROOT_DIR}" | |
git clone -b $BRANCH_GENESIS_INIT_BENCHMARKS https://github.com/OpenFusionist/genesis-init-benchmarks.git genesis-init-benchmarks | |
- name: Checkout PR branch of benchmarks-data-results | |
uses: actions/checkout@v3 | |
with: | |
repository: OpenFusionist/benchmarks-data-results | |
path: benchmarks-data-result | |
ref: ${{ github.event.pull_request.head.sha }} | |
- name: Copy images.yaml | |
run: | | |
ROOT_DIR=${{ needs.run-gas-benchmarks.outputs.root_dir }} | |
cp "${GITHUB_WORKSPACE}/benchmarks-data-result/images.yaml" "${ROOT_DIR}/genesis-init-benchmarks/" | |
- name: Run genesis init speed benchmarks | |
run: | | |
CLIENT=${{ matrix.client }} | |
SIZE=${{ matrix.size }} | |
REPETITIONS=${{ needs.run-gas-benchmarks.outputs.repetitions }} | |
ROOT_DIR=${{ needs.run-gas-benchmarks.outputs.root_dir }} | |
DATE=${{ needs.run-gas-benchmarks.outputs.date }} | |
cd "$ROOT_DIR/genesis-init-benchmarks" | |
./runSpeed.sh -t "tests/" -c "$CLIENT" -r "$REPETITIONS" -o "results-$DATE/speed" -s "$SIZE" | |
python3 report_metadata.py "$DATE" speed | |
sudo apt-get install -y jq | |
max_value=$(jq -r '.speed["'"${{ matrix.client }}"'"]["'"${{ matrix.size }}"'"].first.max' "results-$DATE/speed/reports/speed.json") | |
if [ "$max_value" = "0" ] || [ -z "$max_value" ]; then | |
echo "Client '${{ matrix.client }}' has no valid data (max=0 or missing)." | |
exit 1 | |
else | |
echo "Client '${{ matrix.client }}' has valid data (max=$max_value)." | |
fi | |
- name: Zip the results folder | |
run: | | |
ROOT_DIR=${{ needs.run-gas-benchmarks.outputs.root_dir }} | |
DATE=${{ needs.run-gas-benchmarks.outputs.date }} | |
cd "$ROOT_DIR/genesis-init-benchmarks" | |
zip -r reports-$DATE-speed.zip "results-$DATE/speed/reports" | |
- name: Upload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: genesis-init-speed-${{ matrix.client }}-${{ matrix.size }}-${{ needs.run-gas-benchmarks.outputs.date }} | |
path: ${{ needs.run-gas-benchmarks.outputs.root_dir }}/genesis-init-benchmarks/reports-${{ needs.run-gas-benchmarks.outputs.date }}-speed.zip | |
run-genesis-init-memory-benchmarks: | |
runs-on: ubuntu-latest | |
needs: run-genesis-init-speed-benchmarks | |
outputs: | |
matrix: ${{ needs.run-genesis-init-speed-benchmarks.outputs.matrix }} | |
date: ${{ needs.run-genesis-init-speed-benchmarks.outputs.date }} | |
root_dir: ${{ needs.run-genesis-init-speed-benchmarks.outputs.root_dir }} | |
clients: ${{ needs.run-genesis-init-speed-benchmarks.outputs.clients }} | |
sizes: ${{ needs.run-genesis-init-speed-benchmarks.outputs.sizes }} | |
repetitions: ${{ needs.run-genesis-init-speed-benchmarks.outputs.repetitions }} | |
strategy: | |
max-parallel: 8 | |
matrix: | |
client: ${{ fromJson(needs.run-genesis-init-speed-benchmarks.outputs.matrix).Client }} | |
size: ${{ fromJson(needs.run-genesis-init-speed-benchmarks.outputs.matrix).Size }} | |
fail-fast: false | |
steps: | |
- name: Clone genesis init benchmarks repo | |
run: | | |
ROOT_DIR=${{ needs.run-genesis-init-speed-benchmarks.outputs.root_dir }} | |
BRANCH_GENESIS_INIT_BENCHMARKS=main | |
mkdir -p "${ROOT_DIR}" | |
cd "${ROOT_DIR}" | |
git clone -b $BRANCH_GENESIS_INIT_BENCHMARKS https://github.com/OpenFusionist/genesis-init-benchmarks.git genesis-init-benchmarks | |
- name: Checkout PR branch of benchmarks-data-results | |
uses: actions/checkout@v3 | |
with: | |
repository: OpenFusionist/benchmarks-data-results | |
path: benchmarks-data-result | |
ref: ${{ github.event.pull_request.head.sha }} | |
- name: Copy images.yaml | |
run: | | |
ROOT_DIR=${{ needs.run-genesis-init-speed-benchmarks.outputs.root_dir }} | |
cp "${GITHUB_WORKSPACE}/benchmarks-data-result/images.yaml" "${ROOT_DIR}/genesis-init-benchmarks/" | |
- name: Run genesis init memory benchmarks | |
run: | | |
CLIENT=${{ matrix.client }} | |
SIZE=${{ matrix.size }} | |
REPETITIONS=${{ needs.run-genesis-init-speed-benchmarks.outputs.repetitions }} | |
ROOT_DIR=${{ needs.run-genesis-init-speed-benchmarks.outputs.root_dir }} | |
DATE=${{ needs.run-genesis-init-speed-benchmarks.outputs.date }} | |
cd "$ROOT_DIR/genesis-init-benchmarks" | |
./runMemory.sh -t "tests/" -c "$CLIENT" -r "$REPETITIONS" -o "results-$DATE/memory" -s "$SIZE" | |
python3 report_metadata.py "$DATE" memory | |
sudo apt-get install -y jq | |
max_value=$(jq -r '.memory["'"${{ matrix.client }}"'"]["'"${{ matrix.size }}"'"].first.max' "results-$DATE/memory/reports/memory.json") | |
if [ "$max_value" = "0" ] || [ -z "$max_value" ]; then | |
echo "Client '${{ matrix.client }}' has no valid data (max=0 or missing)." | |
exit 1 | |
else | |
echo "Client '${{ matrix.client }}' has valid data (max=$max_value)." | |
fi | |
max_value=$(jq -r '.memory["'"${{ matrix.client }}"'"]["'"${{ matrix.size }}"'"].second.max' "results-$DATE/memory/reports/memory.json") | |
if [ "$max_value" = "0" ] || [ -z "$max_value" ]; then | |
echo "Client '${{ matrix.client }}' has no valid data (max=0 or missing)." | |
exit 1 | |
else | |
echo "Client '${{ matrix.client }}' has valid data (max=$max_value)." | |
fi | |
- name: Zip the results folder | |
run: | | |
ROOT_DIR=${{ needs.run-genesis-init-speed-benchmarks.outputs.root_dir }} | |
DATE=${{ needs.run-genesis-init-speed-benchmarks.outputs.date }} | |
cd "$ROOT_DIR/genesis-init-benchmarks" | |
zip -r reports-$DATE-memory.zip "results-$DATE/memory/reports" | |
- name: Upload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: genesis-init-memory-${{ matrix.client }}-${{ matrix.size }}-${{ needs.run-genesis-init-speed-benchmarks.outputs.date }} | |
path: ${{ needs.run-genesis-init-speed-benchmarks.outputs.root_dir }}/genesis-init-benchmarks/reports-${{ needs.run-genesis-init-speed-benchmarks.outputs.date }}-memory.zip | |
run-burntpix-benchmarks: | |
runs-on: ubuntu-latest | |
needs: run-genesis-init-memory-benchmarks | |
outputs: | |
matrix: ${{ needs.run-genesis-init-memory-benchmarks.outputs.matrix }} | |
date: ${{ needs.run-genesis-init-memory-benchmarks.outputs.date }} | |
root_dir: ${{ needs.run-genesis-init-memory-benchmarks.outputs.root_dir }} | |
clients: ${{ needs.run-genesis-init-memory-benchmarks.outputs.clients }} | |
sizes: ${{ needs.run-genesis-init-memory-benchmarks.outputs.sizes }} | |
repetitions: ${{ needs.run-genesis-init-memory-benchmarks.outputs.repetitions }} | |
steps: | |
- name: Create /tmp/ directory | |
run: mkdir -p /tmp/ | |
- name: Set permissions for /tmp/ | |
run: sudo chmod -R 777 /tmp/ | |
- name: Clone burntpix benchmarks repo | |
run: | | |
ROOT_DIR=${{ needs.run-genesis-init-memory-benchmarks.outputs.root_dir }} | |
BRANCH_BURNTPIX_BENCHMARKS=burnt-rc-1 | |
mkdir -p "${ROOT_DIR}" | |
cd "${ROOT_DIR}" | |
git clone -b $BRANCH_BURNTPIX_BENCHMARKS https://github.com/OpenFusionist/gas-benchmarks.git burntpix-benchmarks | |
- name: Checkout PR branch of benchmarks-data-results | |
uses: actions/checkout@v3 | |
with: | |
repository: OpenFusionist/benchmarks-data-results | |
path: benchmarks-data-result | |
ref: ${{ github.event.pull_request.head.sha }} | |
- name: Copy images.yaml | |
run: | | |
ROOT_DIR=${{ needs.run-genesis-init-memory-benchmarks.outputs.root_dir }} | |
cp "${GITHUB_WORKSPACE}/benchmarks-data-result/images.yaml" "${ROOT_DIR}/burntpix-benchmarks/" | |
- name: Run burntpix benchmarks | |
run: | | |
# Use const due to can't handle ${{ needs.run-genesis-init-memory-benchmarks.outputs.clients }} | |
CLIENT="nethermind,geth,reth,erigon,besu" | |
REPETITIONS=${{ needs.run-genesis-init-memory-benchmarks.outputs.repetitions }} | |
ROOT_DIR=${{ needs.run-genesis-init-memory-benchmarks.outputs.root_dir }} | |
DATE=${{ needs.run-genesis-init-memory-benchmarks.outputs.date }} | |
cd "$ROOT_DIR/burntpix-benchmarks" | |
./run.sh -t "testburnt/" -w "./testburntwarm/warm.txt" -c "$CLIENT" -r "$REPETITIONS" -o "results-$DATE" | |
python3 report_metadata.py "$DATE" | |
sudo apt-get install -y jq | |
max_value=$(jq -r '.["'"${{ matrix.client }}"'"].GasLimit.max' "results-$DATE/reports/result.json") | |
if [ "$max_value" = "0" ] || [ -z "$max_value" ]; then | |
echo "Client '${{ matrix.client }}' has no valid data (max=0 or missing)." | |
exit 1 | |
else | |
echo "Client '${{ matrix.client }}' has valid data (max=$max_value)." | |
fi | |
- name: Zip the results folder | |
run: | | |
ROOT_DIR=${{ needs.run-genesis-init-memory-benchmarks.outputs.root_dir }} | |
DATE=${{ needs.run-genesis-init-memory-benchmarks.outputs.date }} | |
cd "$ROOT_DIR/burntpix-benchmarks" | |
zip -r reports-$DATE.zip "results-$DATE/reports" | |
- name: Upload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: burntpix-benchmarks-${{ matrix.client }}-${{ needs.run-genesis-init-memory-benchmarks.outputs.date }} | |
path: ${{ needs.run-genesis-init-memory-benchmarks.outputs.root_dir }}/burntpix-benchmarks/reports-${{ needs.run-genesis-init-memory-benchmarks.outputs.date }}.zip | |
push-results: | |
runs-on: ubuntu-latest | |
needs: run-burntpix-benchmarks | |
steps: | |
- name: Clone benchmarks data result repo | |
run: | | |
ROOT_DIR=${{ needs.run-burntpix-benchmarks.outputs.root_dir }} | |
BRANCH_BENCHMARKS_DATA_RESULT=main | |
mkdir -p "${ROOT_DIR}" | |
cd "${ROOT_DIR}" | |
git clone -b $BRANCH_BENCHMARKS_DATA_RESULT https://github.com/OpenFusionist/benchmarks-data-results.git benchmarks-data-result | |
- name: Push results | |
run: | | |
ROOT_DIR=${{ needs.run-burntpix-benchmarks.outputs.root_dir }} | |
cd "$ROOT_DIR/benchmarks-data-result" | |
git status |