Run Performance Tests Locally
Run Solo E2E performance tests locally, including setup, execution, optional local build path configuration, and branch workflow triggering.
Overview
This guide shows how to run the Solo E2E performance test on a local machine.
Prerequisites
task,node,npm,kubectl, andkindinstalled- Docker running
- Solo dependencies installed (
npm ci)
Run the Performance Test
From the repository root:
task test-setup
task test-e2e-performance
The test uses one-shot single deploy/destroy flow and then runs rapid-fire load tests.
Optional: Use a Local Consensus Node Build
If you already have a local consensus node build, set SOLO_LOCAL_BUILD_PATH so
commands that consume --local-build-path can use it by default:
export SOLO_LOCAL_BUILD_PATH="/absolute/path/to/hiero-consensus-node/hedera-node/data"
task test-setup
task test-e2e-performance
Optional: Shorten Test Duration
You can shorten load-test duration while iterating:
export ONE_SHOT_METRICS_TEST_DURATION_IN_MINUTES=2
task test-e2e-performance
Run the GitHub Performance Workflow for a Branch
You can run the repository performance workflow against any pushed Solo branch.
Option 1: Using gh CLI
export SOLO_BRANCH="<your-branch-name>"
gh workflow run "Performance Test Solo Deployment" --ref "${SOLO_BRANCH}" --repo hiero-ledger/solo
Watch the latest run for that branch:
RUN_ID=$(gh run list --workflow "Performance Test Solo Deployment" --branch "${SOLO_BRANCH}" --limit 1 --json databaseId -q '.[0].databaseId')
gh run watch "${RUN_ID}" --repo hiero-ledger/solo
Option 2: Using GitHub Web UI
- Open
https://github.com/hiero-ledger/solo/actions/workflows/flow-performance-test.yaml. - Click
Run workflow. - Select your branch in the branch dropdown.
- Click
Run workflowto start the run.