Load Testing
Poktroll load-testing suite.
Overview
The load-testing suite is built on Gherkin, enabling the creation of simple and human-readable tests.
Dependencies
Load Test Manifests
Load test manifests are YAML files that define the network environment for test execution. These files specify properties such as blockchain account addresses for funding and staking applications, and for utilization by suppliers and gateways. The LocalNet manifest serves as a comprehensive example, including detailed comments for each manifest property.
Test Features
Test features are located in the load-testing/tests directory, encompassing various scenarios.
Feature files are composed of one or more Scenario
s (or Scenario Outline
s), each of which is composed of one or more steps. For example:
Feature: Loading anvil node only
Scenario Outline: Anvil can handle the maximum number of concurrent users
Given anvil is running
And load of <num_requests> concurrent requests for the "eth_blockNumber" JSON-RPC method
Then load is handled within <timeout> seconds
Examples:
| num_requests | timeout |
| 10 | 1 |
| 100 | 1 |
| 1000 | 5 |
| 10000 | 10 |
This natural language syntax is parsed and used to match and execute the corresponding step definitions using gocuke.
Executing Tests
LocalNet Environment
To execute tests on LocalNet:
- Ensure LocalNet is operational.
- In the
localnet_config.yaml
file, setgateways.count
andrelayminers.count
to3
. - Run
make acc_initialize_pubkeys
to initialize blockchain state public keys. - Run
make test_load_relays_stress_localnet
to run the LocalNet stress-test.
Interpreting Results
- The CLI output displays standard Go test results. Successful tests are indicated by
PASS
, while failures are denoted byFAIL
with accompanying error messages. - During test execution, the observability stack continuously collects metric data from offchain actors. On LocalNet, Grafana is accessible on port 3003. The Stress test and Load Testing dashboards provide valuable insights into system status.
Non-Ephemeral Networks (TestNets, MainNet, etc)
These networks are generated with random addresses, necessitating modifications to the load test manifest to reflect network-specific accounts.
Note: Such networks typically involve other participants, allowing load testing against offchain actors deployed by third parties. Consequently, metrics and logs may not be available when testing against uncontrolled software. For comprehensive observability, consider creating a new service with custom gateways and suppliers, and conduct tests against this controlled environment.
Prerequisites
- A account with sufficient tokens for application funding and staking, accessible on the local keychain (e.g.,
poktrolld keys list
). - A list of target gateways to which relay requests will be sent throughout the course of the test.
- For custom service testing, ensure supplier(s') corresponding relayminer(s) and custom service process are properly configured, running, and ready to process requests.
Manifest Modification
Using loadtest_manifest_example.yaml as a template, modify the values to align with the test requirements.
Test Execution
Utilize the provided makefile target to run the relays_stress.feature
with the modified manifest. By default, the example manifest file is used. You can specify a different manifest file by setting the LOAD_TEST_CUSTOM_MANIFEST
environment variable.
To run the stress test using the default manifest:
make test_load_relays_stress_custom
To run the stress test with a custom manifest:
LOAD_TEST_CUSTOM_MANIFEST=your_new_manifest.yaml make test_load_relays_stress_custom
Result Analysis
For tests conducted against community-hosted suppliers and gateways, analysis is limited to blockchain transactions and test output. When testing against a custom-deployed service, comprehensive observability is available, including metrics, logs, and system behavior under load, accessible through Grafana or other configured monitoring tools.
Developing Custom Tests
For custom test development, refer to the gocuke documentation. The anvil test provides a small but practical reference implementation.