-
Notifications
You must be signed in to change notification settings - Fork 12
Home
Assertoor provides distribution-specific executables for Windows, Linux, and macOS.
-
Download the Latest Release:
Navigate to the Releases page and download the latest version suitable for your operating system. -
Run the Executable:
After downloading, run the executable with a test configuration file. The command will be similar to the following:./assertoor --config=./test-config.yaml
If you prefer to build Assertoor from source, ensure you have Go >= 1.22
and Make installed on your machine. Assertoor is tested on Debian, but it should work on other operating systems as well.
-
Clone the Repository:
Use the following commands to clone the Assertoor repository and navigate to its directory:git clone https://github.com/ethpandaops/assertoor.git cd assertoor
-
Build the Tool:
Compile the source code by running:make build
After building, the
assertoor
executable can be found in thebin
folder. -
Run Assertoor:
Execute Assertoor with a test configuration file:./bin/assertoor --config=./test-config.yaml
Assertoor also offers a Docker image, which can be found at ethpandaops/assertoor on Docker Hub.
Available Tags:
-
latest
: The latest stable release. -
v1.0.0
: Version-specific images for all releases. -
master
: The latestmaster
branch version (automatically built). -
master-xxxxxxx
: Commit-specific builds for eachmaster
commit (automatically built).
Running with Docker:
-
Start the Container:
To run Assertoor in a Docker container with your test configuration, use the following command:docker run -d --name=assertoor -v $(pwd):/config -p 8080:8080 -it ethpandaops/assertoor:latest --config=/config/test-config.yaml
-
View Logs:
To follow the container's logs, use:docker logs assertoor --follow
-
Stop the Container:
To stop and remove the Assertoor container, execute:docker rm -f assertoor
The Assertoor test configuration file is a crucial component that outlines the structure and parameters of your tests.
It contains general settings, endpoints, validator names, global variables, and a list of tests to run.
The configuration file is structured as follows:
coordinator:
maxConcurrentTests: 1 # max number of tests to run concurrently
testRetentionTime: 336h # delete test run (logs + status) after that duration
web:
server:
host: "0.0.0.0"
port: 8080
api:
enabled: true # enable rest api
frontend:
enabled: true # enable web ui
endpoints:
- name: "node-1"
executionUrl: "http://127.0.0.1:8545"
consensusUrl: "http://127.0.0.1:5052"
validatorNames:
inventoryYaml: "./validator-names.yaml"
inventoryUrl: "https://config.dencun-devnet-12.ethpandaops.io/api/v1/nodes/validator-ranges"
inventory:
"0-199": "lighthouse-geth-1"
"200-399": "teku-besu-1"
globalVars:
validatorPairNames:
- "lighthouse-geth-.*"
- "teku-besu-.*"
tests:
# test test1
- name: "Test with local tasks"
timeout: 48h
config: {}
tasks: []
cleanupTasks: []
externalTests:
- file: ./check-block-proposals2.yaml
name: "Test with separate list of tasks"
timeout: 48h
config: {}
-
coordinator
:
Manages the execution of tests, specifying the maximum number of tests that can run concurrently (maxConcurrentTests
) and how long to retain test runs, including logs and status, after completion (testRetentionTime
). -
endpoints
:
A list of Ethereum consensus and execution clients. Each endpoint includes URLs for both RPC endpoints and a name for reference in subsequent tests. -
web
:
Configurations for the web api & frontend, detailing server host and port settings. -
validatorNames
:
Defines a mapping of validator index ranges to their respective names.
This mapping can be defined directly in the configuration file, imported from an external YAML file, or fetched from a specified URL.
These named validator ranges can be referenced in tests for targeted actions and checks. -
globalVars
:
A collection of global variables that are made available to all tests and tasks.
These variables can be used to maintain consistency and reusability across different test scenarios.
For an in-depth explanation, see the "Variables" section of the documentation. -
tests
:
A list of tests, each with a specific set of tasks.
Every test is identified by a unique name and may include an optional execution timeout.
Theconfig
section within each test allows for the specification of additional variables, which are passed down to the tasks within that test.
Moreover, a suite of cleanup tasks can be defined for each test, ensuring orderly and thorough execution, regardless of the test outcome.
Detailed guidelines on task configuration can be found in the "Task Configuration" section of the documentation. -
externalTests
:
This feature enables the integration of tests that are defined in separate files, fostering a modular and scalable test configuration approach.
It allows for better organization and management of complex testing scenarios.
When enabled, Assertoor offers a REST API that facilitates interaction with the testing framework, enabling users to programmatically fetch statuses and results of tests and tasks. Additionally, the API supports basic operations such as scheduling or canceling test runs, making it a powerful tool for automating and integrating Assertoor into broader testing and CI/CD pipelines.
-
Status and Results Retrieval: Users can query the API to obtain detailed status updates and results for both tests and individual tasks, allowing for real-time monitoring and analysis of test executions.
-
Test Management: The API supports scheduling new test runs and canceling existing ones, providing flexibility in managing test execution according to dynamic testing requirements or conditions.
-
Integration Friendly: The REST API's standard interface ensures it can be easily integrated with external tools and systems, enhancing Assertoor's utility in automated testing environments.
The detailed API documentation, including all supported endpoints, request formats, and response structures, is accessible via the Assertoor web UI. This comprehensive documentation is designed to be user-friendly, offering examples and explanations to facilitate easy adoption and integration of the API into your workflows.
To access the API documentation, ensure the Assertoor web interface is enabled and navigate to the designated URL. The documentation provides interactive examples and the ability to test endpoints directly from your browser, offering a hands-on approach to learning and utilizing the REST API.
Assertoor allows you to set up tests to check various aspects of the Ethereum network. You can organize these tests in two ways: directly within your main configuration file or through external files for more complex scenarios. Here’s how it works:
Local tests are defined in your main Assertoor configuration file. You can list tasks that you want to run as part of your test, along with any cleanup tasks to run afterward, regardless of whether your test passes or fails.
- id: "test1"
name: "Test with local tasks"
timeout: "48h"
config: {}
tasks: []
cleanupTasks: []
schedule:
startup: true
cron:
- "* * * * *"
-
id
:
A unique identifier for your test. -
name
:
The test's name. -
timeout
:
How long to run the test before stopping it. This is optional. -
config
:
A place to set static variables for your test. Optional. -
tasks
:
The tasks to run for your test. -
cleanupTasks
:
Tasks that clean up after your main tasks. These run no matter if the main tasks pass or fail. This is optional. -
schedule
:
Determines when your test runs. You can set it to start when Assertoor starts or on a schedule using cron format. This is optional.
External test playbooks, loaded via the file
attribute in the Assertoor configuration, follow a structured format. These playbooks allow for defining comprehensive tests with specific tasks, variable configurations, and scheduling options.
Example External Test Playbook:
id: test1
name: "Test 1"
timeout: 1h
config:
# walletPrivkey: ""
# validatorPairNames: []
configVars: {}
tasks: []
cleanupTasks: []
schedule:
startup: true
cron:
- "* * * * *"
Key Properties Explained:
-
id
: A unique identifier for the test, allowing for easy reference. -
name
: The descriptive name of the test, providing clarity on its purpose. -
timeout
: Specifies the duration after which the test should be considered failed if not completed. -
config
: Static variable configuration, where you can define variables directly used by the test. -
configVars
: Dynamic variable configuration that copies variables from the global scope, supporting complex expressions through jq syntax. -
tasks
: The list of tasks to be executed as part of the test. Refer to the task configuration section for detailed task structures. -
cleanupTasks
: Specifies tasks to be executed after the main tasks, regardless of their success or failure. -
schedule
: Determines when the test should be run. If omitted, the test is scheduled to start upon Assertoor startup. It also supports cron expressions for more precise scheduling.
This format provides a flexible and powerful way to define tests outside the main configuration file, allowing for modular test management and reusability across different scenarios or environments.
Each task in Assertoor is defined with specific parameters to control its execution. Here's a breakdown of how to configure a task:
A typical task in Assertoor is structured as follows:
name: generate_transaction
title: "Send test transaction"
timeout: 5m
config:
targetAddress: "..."
# ...
configVars:
privateKey: "walletPrivateKey"
# ...
-
name
:
The action that the task should perform. It must correspond to a valid name from the list of supported tasks.
This can be a simple action like running a shell script (run_shell
) or a more complex operation (generate_transaction
).
For a comprehensive list of supported tasks, refer to the "Supported Tasks" section of this documentation. -
title
:
A descriptive title for the task. It should be unique and meaningful, as it appears on the web frontend and in the logs.
The title helps in identifying and differentiating tasks. -
timeout
:
An optional parameter specifying the maximum duration for task execution.
If the task exceeds this timeout, it is cancelled and marked as a failure. This parameter helps in managing task execution time and resources. -
config
:
A set of specific settings required for running the task.
The available settings vary depending on the task name and are detailed in the respective task documentation section. -
configVars
:
This parameter allows for the use of variables in the task configuration.
In the given example, the value ofwalletPrivateKey
is assigned to theprivateKey
config setting of the task.
To make this work, thewalletPrivateKey
variable must be defined in a higher scope (globalVars / test config) or set by a previous task (effectively allowing reusing results from these tasks).
This feature enables dynamic configuration based on predefined or dynamically set variables.
With this structure, Assertoor tasks can be precisely defined and tailored to fit various testing scenarios.
Some tasks allow defining subtasks within their configuration, which enables nesting and concurrent execution of tasks.
The next sections will detail the supported tasks and how to effectively utilize the config
parameters.
Tasks in Assertoor are fundamental building blocks for constructing comprehensive and dynamic test scenarios. They are designed to be small, logical components that can be combined and configured to meet various testing requirements. Understanding the nature of these tasks, their states, results, and categories is key to effectively using Assertoor.
When a task is executed, it goes through different states and yields specific results:
Task States
-
pending
: The initial state of a task before execution. -
running
: The state when a task is actively being executed by the task scheduler. -
completed
: The final state indicating that a task has finished its execution (regardless of success or failure).
Task Results
The result of a task indicates its outcome and can change at any point during its execution:
-
none
: The initial result status of a task, indicating that no definitive outcome has been determined yet. -
success
: Indicates that the task has achieved its intended objective.
This result can be set at any point during task execution and does not necessarily imply the task has completed. -
failure
: Indicates that the task encountered an issue or did not meet the specified conditions.
Similar tosuccess
, this result can be updated during the task's execution and does not automatically mean the task has completed.
It's important to note that while the task result can be updated at any time during execution, it becomes final once the task completes. After a task has reached its completion state, the result is conclusive and represents the definitive outcome of that task.
Tasks in Assertoor are generally categorized based on their primary function and usage in the testing process. It's important to note that this categorization is not strict. While many tasks fit into these categories, some tasks may overlap across multiple categories or not fit into any specific category. However, the majority of currently supported tasks in Assertoor follow this schema:
-
Flow Tasks (
run_task
prefix): These tasks are central to structuring and ordering the execution of other tasks. Flow tasks can define subtasks in their configuration, executing them according to specific logic, such as sequential/concurrent or matrix-based execution. They remain in therunning
state while any of their subtasks are active, and move tocompleted
once all subtasks are done. The result of flow tasks is derived from the results of the subtasks, following the flow task's logic. This means the overall outcome of a flow task depends on how its subtasks perform and interact according to the predefined flow. -
Check Tasks (
check_
prefix): Check tasks are designed to monitor the network and verify certain conditions or states. They typically run continuously, updating their result as they progress. A check task completes by its own only when its result is conclusive and won’t change in the future. -
Generate Tasks (
generate_
prefix): These tasks perform actions on the network, such as sending transactions or executing deposits/exits. Generate tasks remain in therunning
state while performing their designated actions and move tocompleted
upon finishing their tasks.
The categorization serves as a general guide to understanding the nature and purpose of different tasks within Assertoor. As the tool evolves, new tasks may be introduced that further expand or blend these categories, offering enhanced flexibility and functionality in network testing.
The following sections will detail individual tasks within these categories, providing insights into their specific functions, configurations, and use cases.
The check_clients_are_healthy
task is designed to ensure the health of specified clients. It verifies if the clients are reachable and synchronized on the same network.
-
clientPattern
:
A regular expression pattern used to specify which clients to check. This allows for targeted health checks of specific clients or groups of clients within the network. A blank pattern targets all clients. -
pollInterval
:
The interval at which the health check is performed. Set this to define how frequently the task should check the clients' health. -
skipConsensusCheck
:
A boolean value that, when set totrue
, skips the health check for consensus clients. Useful if you only want to focus on execution clients. -
skipExecutionCheck
:
A boolean value that, when set totrue
, skips the health check for execution clients. Use this to exclusively check the health of consensus clients. -
expectUnhealthy
:
A boolean value that inverts the expected result of the health check. Whentrue
, the task succeeds if the clients are not ready or unhealthy. This can be useful in test scenarios where client unavailability is expected or being tested. -
minClientCount
:
The minimum number of clients that must match theclientNamePatterns
and pass the health checks for the task to succeed. A value of 0 indicates that all matching clients need to pass the health check. Use this to set a threshold for the number of healthy clients required by your test scenario. -
maxUnhealthyCount
:
Specifies the maximum number of unhealthy clients allowed before the health check fails. A value of 0 means that any unhealthy client will cause the health check to fail, enforcing strict health criteria. -
failOnCheckMiss
:
Determines the task's behavior when a health check fails. If true, the task reports a failure upon the first unsuccessful health check. If false, the task continues to poll the clients until a successful check occurs, allowing for temporary issues to be resolved without immediate failure.
These are the default settings for the check_clients_are_healthy
task:
- name: check_clients_are_healthy
config:
clientPattern: ""
pollInterval: 5s
skipConsensusCheck: false
skipExecutionCheck: false
expectUnhealthy: false
minClientCount: 0
maxUnhealthyCount: -1
failOnCheckMiss: false
The check_consensus_attestation_stats
task is designed to monitor attestation voting statistics on the consensus chain, ensuring that voting patterns align with specified criteria.
-
minTargetPercent
:
The minimum percentage of correct target votes per checked epoch required for the task to succeed. The range is 0-100%. -
maxTargetPercent
:
The maximum allowable percentage of correct target votes per checked epoch for the task to succeed. The range is 0-100%. -
minHeadPercent
:
The minimum percentage of correct head votes per checked epoch needed for the task to succeed. The range is 0-100%. -
maxHeadPercent
:
The maximum allowable percentage of correct head votes per checked epoch for the task to succeed. The range is 0-100%. -
minTotalPercent
:
The minimum overall voting participation per checked epoch in percent needed for the task to succeed. The range is 0-100%. -
maxTotalPercent
:
The maximum allowable overall voting participation per checked epoch for the task to succeed. The range is 0-100%. -
failOnCheckMiss
:
Determines whether the task should stop with a failure result if a checked epoch does not meet the specified voting ranges.
Iffalse
, the task continues checking subsequent epochs until it succeeds or times out. -
minCheckedEpochs
:
The minimum number of consecutive epochs that must pass the check for the task to succeed.
These are the default settings for the check_consensus_attestation_stats
task:
- name: check_consensus_attestation_stats
config:
minTargetPercent: 0
maxTargetPercent: 100
minHeadPercent: 0
maxHeadPercent: 100
minTotalPercent: 0
maxTotalPercent: 100
failOnCheckMiss: false
minCheckedEpochs: 1
The check_consensus_block_proposals
task assesses consensus block proposals against specified criteria to ensure they comply with expected blockchain operations and standards. This task is crucial for validating the integrity and content of blocks proposed on the consensus layer.
-
blockCount
:
The number of blocks that need to match your criteria for the task to be successful. -
graffitiPattern
:
A regex pattern to match against the graffiti field of the block, allowing for specific textual content verification. -
validatorNamePattern
:
A regex pattern to select validators by name involved in block proposals. -
extraDataPattern
:
A regex pattern to validate the extra data field within the block header. -
minAttestationCount
:
The minimum number of attestations required in the block to satisfy the check. -
minDepositCount
:
The minimum number of deposit events that must be included in the block. -
minExitCount
:
The minimum number of validator exits required in the block. -
minSlashingCount
:
The minimum number of slashing events the block must contain. -
minAttesterSlashingCount
:
The minimum number of attester slashing operations required in the block. -
minProposerSlashingCount
:
The minimum number of proposer slashing operations the block must include. -
minBlsChangeCount
:
The minimum number of BLS key changes needed in the block. -
minWithdrawalCount
:
The minimum number of withdrawals that must be processed in the block. -
minTransactionCount
:
The minimum number of transactions (of any type) required in the block. -
minBlobCount
:
The minimum number of blob sidecars that must be included in the block. -
minDepositRequestCount
:
The minimum number of deposit request operations needed in the block. -
minWithdrawalRequestCount
:
The minimum number of withdrawal requests required in the block. -
minConsolidationRequestCount
:
The minimum number of consolidation requests that the block must include. -
expectDeposits
:
A list of validator public keys, specifying which validators should have deposit transactions included in the block. -
expectExits
:
A list of validator public keys indicating which validators should have exit transactions included in the block. -
expectSlashings
:
A list detailing expected slashing operations in the block, with each entry specifying a public key and a slashing type (attester
orproposer
). If the slashing type is omitted, any type of slashing is accepted.{publicKey: "0x0000...", slashingType: "attester"|"proposer"}
-
expectBlsChanges
:
Specifies expected BLS key changes in the block, with each object detailing a public key and a new address for the key change.{publicKey: "0x0000...", address: "0x00..."}
-
expectWithdrawals
:
Specifies expected withdrawal operations, including public keys, destination addresses, and minimum withdrawal amounts.{publicKey: "0x0000...", address: "0x00...", minAmount: 0}
-
expectDepositRequests
:
Specifies expected deposit request operations, each object detailing the public key, withdrawal credentials, and deposit amount.{publicKey:"0x0000...", withdrawalCredentials: "0x0000...", amount: 0}
-
expectWithdrawalRequests
:
Specifies expected withdrawal request operations, each detailing the source address, validator public key, and amount to be withdrawn.{sourceAddress:"0x0000...", validatorPubkey: "0x0000...", amount: 0}
-
expectConsolidationRequests
:
Specifies expected consolidation request operations, each specifying source addresses, source public keys, and target public keys for consolidation.{sourceAddress:"0x0000...", sourcePubkey: "0x0000...", targetPubkey: "0x0000..."}
Default settings for the check_consensus_block_proposals
task:
- name: check_consensus_block_proposals
config:
blockCount: 1
graffitiPattern: ""
validatorNamePattern: ""
extraDataPattern: ""
minAttestationCount: 0
minDepositCount: 0
minExitCount: 0
minSlashingCount: 0
minAttesterSlashingCount: 0
minProposerSlashingCount: 0
minBlsChangeCount: 0
minWithdrawalCount: 0
minTransactionCount: 0
minBlobCount: 0
minDepositRequestCount: 0
minWithdrawalRequestCount: 0
minConsolidationRequestCount: 0
expectDeposits: []
expectExits: []
expectSlashings: []
expectBlsChanges: []
expectWithdrawals: []
expectDepositRequests: []
expectWithdrawalRequests: []
expectConsolidationRequests: []
The check_consensus_finality
task checks the finality status of the consensus chain. Finality in a blockchain context refers to the point where a block's transactions are considered irreversible.
-
minUnfinalizedEpochs
:
The minimum number of epochs that are allowed to be not yet finalized. -
maxUnfinalizedEpochs
:
The maximum number of epochs that can remain unfinalized before the task fails. -
minFinalizedEpochs
:
The minimum number of epochs that must be finalized for the task to be successful. -
failOnCheckMiss
:
If set totrue
, the task will stop with a failure result if the finality status does not meet the criteria specified in the other parameters.
Iffalse
, the task will not fail immediately and will continue checking.
These are the default settings for the check_consensus_finality
task:
- name: check_consensus_finality
config:
minUnfinalizedEpochs: 0
maxUnfinalizedEpochs: 0
minFinalizedEpochs: 0
failOnCheckMiss: false
The check_consensus_forks
task is designed to check for forks in the consensus layer of the blockchain. Forks occur when there are divergences in the blockchain, leading to two or more competing chains.
-
minCheckEpochCount
:
The minimum number of epochs to check for forks. -
maxForkDistance
:
The maximum distance allowed before a divergence in the chain is counted as a fork.
The distance is measured by the number of blocks between the heads of the forked chains. -
maxForkCount
:
The maximum number of forks that are acceptable. If the number of forks exceeds this limit, the task will coplete with a failure result.
These are the default settings for the check_consensus_forks
task:
- name: check_consensus_forks
config:
minCheckEpochCount: 1
maxForkDistance: 1
maxForkCount: 0
The check_consensus_proposer_duty
task is designed to check for a specific proposer duty on the consensus chain. It verifies if a matching validator is scheduled to propose a block within a specified future time frame (slot distance).
-
validatorNamePattern
:
A pattern to identify validators by name. This parameter is used to select validators for the duty check based on their names. -
validatorIndex
:
The index of a specific validator to be checked. If this is set, the task focuses on the validator with this index. If it isnull
, the task does not filter by a specific validator index. -
minSlotDistance
:
The minimum slot distance from the current slot at which to start checking for the validator's proposer duty. A value of 0 indicates the current slot. -
maxSlotDistance
:
The maximum number of slots (individual time periods in the blockchain) within which the validator is expected to propose a block. The task succeeds if a matching validator is scheduled for block proposal within this slot distance. -
failOnCheckMiss
:
This parameter specifies the task's behavior if a matching proposer duty is not found within themaxSlotDistance
. If set tofalse
, the task continues running until it either finds a matching proposer duty or reaches its timeout. Iftrue
, the task will fail immediately upon not finding a matching duty.
These are the default settings for the check_consensus_proposer_duty
task:
- name: check_consensus_proposer_duty
config:
validatorNamePattern: ""
validatorIndex: null
maxSlotDistance: 0
failOnCheckMiss: false
The check_consensus_reorgs
task is designed to monitor for reorganizations (reorgs) in the consensus layer of the blockchain. Reorgs occur when the blockchain switches to a different chain due to more blocks being added to it, which can be a normal part of blockchain operation or indicate issues.
-
minCheckEpochCount
:
The minimum number of epochs to be checked for reorgs. An epoch is a specific period in blockchain time. -
maxReorgDistance
:
The maximum allowable distance for a reorg to occur. This is measured in terms of the number of blocks. -
maxReorgsPerEpoch
:
The maximum number of reorgs allowed within a single epoch. If this number is exceeded, it could indicate unusual activity on the blockchain. -
maxTotalReorgs
:
The total maximum number of reorgs allowed across all checked epochs. Exceeding this number could be a sign of instability in the blockchain.
These are the default settings for the check_consensus_reorgs
task:
- name: check_consensus_reorgs
config:
minCheckEpochCount: 1
maxReorgDistance: 0
maxReorgsPerEpoch: 0
maxTotalReorgs: 0
The check_consensus_slot_range
task verifies that the current wall clock time on the consensus chain falls within a specified range of slots and epochs. This is important for ensuring that the chain operates within expected time boundaries.
-
minSlotNumber
:
The minimum slot number that the consensus wall clock should be at or above. This sets the lower bound for the check. -
maxSlotNumber
:
The maximum slot number that the consensus wall clock should not exceed. This sets the upper bound for the slot range. -
minEpochNumber
:
The minimum epoch number that the consensus wall clock should be in or above. Similar to the minSlotNumber, this sets a lower limit, but in terms of epochs. -
maxEpochNumber
:
The maximum epoch number that the consensus wall clock should not go beyond. This parameter sets the upper limit for the epoch range. -
failIfLower
:
A flag that determines the task's behavior if the current wall clock time is below the specified minimum slot or epoch number. Iftrue
, the task will fail in such cases; iffalse
, it will continue without failing.
These are the default settings for the check_consensus_slot_range
task:
- name: check_consensus_slot_range
config:
minSlotNumber: 0
maxSlotNumber: 18446744073709551615
minEpochNumber: 0
maxEpochNumber: 18446744073709551615
failIfLower: false
The check_consensus_sync_status
task checks the synchronization status of consensus clients, ensuring they are aligned with the current state of the blockchain network.
-
clientPattern
:
A regular expression pattern used to specify which clients to check. This allows for targeted health checks of specific clients or groups of clients within the network. A blank pattern targets all clients. -
pollInterval
:
The frequency for checking the clients' sync status. -
expectSyncing
:
Set totrue
if the clients are expected to be in a syncing state, orfalse
if they should be fully synced. -
expectOptimistic
:
Whentrue
, expects clients to be in an optimistic sync state. -
expectMinPercent
:
The minimum sync progress percentage required for the task to succeed. -
expectMaxPercent
:
The maximum sync progress percentage allowable for the task to succeed. -
minSlotHeight
:
The minimum slot height that clients should be synced to. -
waitForChainProgression
:
If set totrue
, the task checks for blockchain progression in addition to synchronization status. Iffalse
, the task solely checks for synchronization status, without waiting for further chain progression.
Default settings for the check_consensus_sync_status
task:
- name: check_consensus_sync_status
config:
clientPattern: ""
pollInterval: 5s
expectSyncing: false
expectOptimistic: false
expectMinPercent: 100
expectMaxPercent: 100
minSlotHeight: 10
waitForChainProgression: false
The check_consensus_validator_status
task is focused on verifying the status of validators on the consensus chain. It checks if the validators are in the expected state, as per the specified criteria.
-
validatorPubKey
:
The public key of the validator to be checked. If specified, the task will focus on the validator with this public key. -
validatorNamePattern
:
A pattern for identifying validators by name. Useful for filtering validators to be checked based on their names. -
validatorIndex
:
The index of a specific validator. If set, the task focuses on the validator with this index. Ifnull
, no filter on validator index is applied. -
validatorStatus
:
A list of allowed validator statuses. The task will check if the validator's status matches any of the statuses in this list. -
minValidatorBalance
:
The minimum balance of the validator to match. -
maxValidatorBalance
:
The maximum balance of the validator to match. -
withdrawalCredsPrefix
:
The withdrawal credentials prefix the validator should have. -
failOnCheckMiss
:
Determines the task's behavior if the validator's status does not match any of the statuses invalidatorStatus
. Iffalse
, the task will continue running and wait for the validator to match the expected status. Iftrue
, the task will fail immediately upon a status mismatch. -
validatorInfoResultVar
:
The name of the variable where the resulting information about the validator will be stored. This includes status, index, balance and any other relevant data fetched during the check.
These are the default settings for the check_consensus_validator_status
task:
- name: check_consensus_validator_status
config:
validatorPubKey: ""
validatorNamePattern: ""
validatorIndex: null
validatorStatus: []
minValidatorBalance: 0
maxValidatorBalance: null
withdrawalCredsPrefix: ""
failOnCheckMiss: false
validatorInfoResultVar: ""
The check_eth_call
task verifies the response from an eth_call
transaction on the Ethereum blockchain. This task is essential for validating contract interactions that do not require gas or change the state of the blockchain but need to be tested for expected outcomes.
-
ethCallData
: The data to be sent in the eth_call transaction, encoded as a hex string. This typically includes the function signature and arguments for contract interactions. -
expectResult
: The expected result of theeth_call
transaction, expressed as a hex string. This is the value that the call is expected to return under normal circumstances and makes the task succeed. -
ignoreResults
: An array of results that, if returned from theeth_call
, should be ignored. This allows the task to be flexible by acknowledging and skipping known but irrelevant results. -
callAddress
: The contract address targeted by theeth_call
. This should be the address of the contract whose methods are being invoked. -
blockNumber
: Specifies the block number at which the state should be queried. A value of0
typically indicates the latest block. -
failOnMismatch
: Determines whether the task should fail if the result of theeth_call
does not match theexpectResult
and is not in the list ofignoreResults
. If set tofalse
, the task will not fail on a result mismatch, allowing further actions or checks to proceed. -
clientPattern
: A regex pattern to select specific client endpoints for sending theeth_call
. This allows targeting of appropriate nodes within the network. -
excludeClientPattern
: A regex pattern to exclude certain clients from being used to make theeth_call
, optimizing the selection of nodes based on the test scenario.
-
callResult
: The result of theeth_call
transaction, returned as a hex string. This output provides direct feedback from the contract method being invoked and is crucial for verifying the result with custom logic.
Default settings for the check_eth_call
task:
- name: check_eth_call
config:
ethCallData: "0x"
expectResult: ""
ignoreResults: []
callAddress: "0x0000000000000000000000000000000000000000"
blockNumber: 0
failOnMismatch: false
clientPattern: ""
excludeClientPattern: ""
The check_execution_sync_status
task checks the synchronization status of execution clients in the blockchain network. It ensures that these clients are syncing correctly with the network's current state.
-
clientPattern
:
A regular expression pattern used to specify which clients to check. This allows for targeted health checks of specific clients or groups of clients within the network. A blank pattern targets all clients. -
pollInterval
:
The interval at which the task checks the clients' sync status. This defines the frequency of the synchronization checks. -
expectSyncing
:
Set this totrue
if the clients are expected to be in a syncing state. Iffalse
, the task expects the clients to be fully synced. -
expectMinPercent
:
The minimum expected percentage of synchronization. Clients should be synced at least to this level for the task to succeed. -
expectMaxPercent
:
The maximum allowable percentage of synchronization. Clients should not be synced beyond this level for the task to pass. -
minBlockHeight
:
The minimum block height that the clients should be synced to. This sets a specific block height requirement for the task. -
waitForChainProgression
:
Iftrue
, the task checks for blockchain progression in addition to the synchronization status. Iffalse
, it only checks for synchronization without waiting for further chain progression.
These are the default settings for the check_execution_sync_status
task:
- name: check_execution_sync_status
config:
clientPattern: ""
pollInterval: 5s
expectSyncing: false
expectMinPercent: 100
expectMaxPercent: 100
minBlockHeight: 10
waitForChainProgression: false
The generate_blob_transactions
task creates and sends a large number of blob transactions to the network. It's configured to operate under various limits, and at least one limit parameter is necessary for the task to function.
-
limitPerBlock
:
The maximum number of blob transactions to generate per block. -
limitTotal
:
The total limit on the number of blob transactions to be generated. -
limitPending
:
The limit based on the number of pending blob transactions. -
privateKey
:
The private key used for transaction generation. -
childWallets
:
The number of child wallets to be created and funded. (If 0, send blob transactions directly from privateKey wallet) -
walletSeed
:
The seed phrase used for generating child wallets. (Will be used in combination with privateKey to generate unique child wallets that do not collide with other tasks) -
refillPendingLimit
:
The maximum number of pending refill transactions allowed. This limit is used to control the refill process for child wallets, ensuring that the number of refill transactions does not exceed this threshold. -
refillFeeCap
:
The maximum fee cap for refilling transactions. -
refillTipCap
:
The maximum tip cap for refill transactions. -
refillAmount
:
The amount to refill in each child wallet. -
refillMinBalance
:
The minimum balance required before triggering a refill. -
blobSidecars
:
The number of blob sidecars to include in each transaction. -
blobFeeCap
:
The fee cap specifically for blob transactions. -
feeCap
:
The maximum fee cap for transactions. -
tipCap
:
The tip cap for transactions. -
gasLimit
:
The gas limit for each transaction. -
targetAddress
:
The target address for transactions. -
randomTarget
:
If true, transactions are sent to random addresses. -
callData
:
Call data to be included in the transactions. -
blobData
:
Data for the blob component of the transactions. -
randomAmount
:
If true, the transaction amount is randomized, usingamount
as limit. -
amount
:
The amount of ETH (in Wei) to be sent in each blob transaction. -
clientPattern
:
A regex pattern for selecting specific client endpoints to send transactions. If unspecified, transactions are sent through any available endpoint. -
excludeClientPattern
:
A regex pattern to exclude certain client endpoints from being used for sending transactions. This allows for more precise control over which clients are utilized.
Default settings for the generate_blob_transactions
task:
- name: generate_blob_transactions
config:
limitPerBlock: 0
limitTotal: 0
limitPending: 0
privateKey: ""
childWallets: 0
walletSeed: ""
refillPendingLimit: 200
refillFeeCap: "500000000000"
refillTipCap: "1000000000"
refillAmount: "1000000000000000000"
refillMinBalance: "500000000000000000"
blobSidecars: 1
blobFeeCap: "10000000000"
feeCap: "100000000000"
tipCap: "2000000000"
gasLimit: 100000
targetAddress: ""
randomTarget: false
callData: ""
blobData: ""
randomAmount: false
amount: "0"
clientPattern: ""
excludeClientPattern: ""
The generate_bls_changes
task is responsible for generating BLS changes and sending these operations to the network. This task is vital for testing the network's ability to handle changes in withdrawal credentials.
-
limitPerSlot
:
The maximum number of BLS change operations to generate for each slot. A slot is a specific time interval in blockchain technology. -
limitTotal
:
The total limit on the number of BLS change operations to be generated by this task. -
mnemonic
:
A mnemonic phrase used to generate validator keys. This is the starting point for creating BLS key changes. -
startIndex
:
The index within the mnemonic from which to start generating validator keys. This determines the starting point for key generation. -
indexCount
:
The number of validator keys to generate from the mnemonic. This sets how many different validators will have their keys changed. -
targetAddress
:
The address to which the validators' withdrawal credentials will be set. This defines the new target for the validators' funds after the BLS key change. -
clientPattern
:
A regex pattern for selecting specific client endpoints to send the BLS change operations. If unspecified, any available endpoint is used. -
excludeClientPattern
:
A regex pattern to exclude certain client endpoints from being utilized for BLS change operations. This parameter allows for excluding specific clients from the task, offering finer control over client selection.
Default settings for the generate_bls_changes
task:
- name: generate_bls_changes
config:
limitPerSlot: 0
limitTotal: 0
mnemonic: ""
startIndex: 0
indexCount: 0
targetAddress: ""
clientPattern: ""
excludeClientPattern: ""
The generate_child_wallet
task is designed to create a new, funded child wallet. This task is especially useful in scenarios requiring the setup of additional wallets for transaction testing, smart contract interactions, or other Ethereum network activities.
-
privateKey
: The private key of the parent wallet used for funding the new child wallet. -
walletSeed
: A seed phrase used for generating the child wallet. This allows for deterministic wallet creation. -
randomSeed
: If set totrue
, the task generates the child wallet using a random seed, resulting in a non-deterministic wallet. -
prefundAmount
: The amount of cryptocurrency to be transferred to the child wallet during prefunding. -
prefundMinBalance
: The minimum balance threshold in the parent wallet required to execute the prefunding. Prefunding occurs only if the parent wallet's balance is above this amount. -
prefundFeeCap
: The maximum fee cap for the prefunding transaction to the child wallet. -
prefundTipCap
: The tip cap for the prefunding transaction, determining the priority fee. -
walletAddressResultVar
: The name of the variable to store the address of the newly created child wallet. This can be used for reference in subsequent tasks. -
walletPrivateKeyResultVar
: The name of the variable to store the private key of the new child wallet. This ensures the child wallet can be accessed and used in later tasks.
Default settings for the generate_child_wallet
task:
- name: generate_child_wallet
config:
privateKey: ""
walletSeed: ""
randomSeed: false
prefundAmount: "1000000000000000000"
prefundMinBalance: "500000000000000000"
prefundFeeCap: "500000000000"
prefundTipCap: "1000000000"
walletAddressResultVar: ""
walletPrivateKeyResultVar: ""
The generate_consolidations
task is designed to create and send consolidation transactions to the Ethereum network. Consolidations are specialized transactions used for consolidating multiple validator balances into a single validator, optimizing the management and operation of validators within the network.
The source validators can be specified in two ways:
- By providing
sourceMnemonic
,sourceStartIndex
&sourceIndexCount
to select the source validators by the pubkeys derived from the mnemonic & key range - By providing
sourceStartValidatorIndex
&sourceIndexCount
to select the source validators by their validator index
-
limitPerSlot
: Specifies the maximum number of consolidation transactions allowed per slot. -
limitTotal
: Sets the total allowable number of consolidation transactions that the task can generate. -
limitPending
: Defines the maximum number of pending consolidation transactions allowed at any given time. -
sourceMnemonic
: The mnemonic used to derive source validator keys; these validators are getting consolidated into the target validator. -
sourceStartIndex
: The starting index for key derivation from the source mnemonic, identifying the first source validator in the consolidation process. -
sourceStartValidatorIndex
: The exact starting validator index from which to begin consolidation, providing precise control over the selection of source validators. -
sourceIndexCount
: The number of validators to include in the consolidation process from the source mnemonic. -
targetPublicKey
: The public key of the target validator to which all consolidated funds will be transferred. -
targetValidatorIndex
: The index of the target validator to which all consolidated funds will be transferred. (alternative to targetPublicKey) -
consolidationEpoch
: The specific blockchain epoch during which the consolidations are to be executed, aligning the transactions with defined blockchain timings. -
walletPrivkey
: The private key of the wallet initiating the consolidation transactions, necessary for transaction authorization. This wallet must be set as withdrawal address for the source & target validator for successful consolidation. -
consolidationContract
: The address of the contract on the blockchain that handles the consolidation operations. -
txAmount
: The amount of ETH to be sent to the consolidation contract in each transaction (for consolidation fees). -
txFeeCap
: The maximum fee cap for each transaction, controlling the cost associated with the consolidation. -
txTipCap
: The tip cap for each transaction, influencing transaction priority. -
txGasLimit
: The gas limit for each transaction, ensuring transactions are executed within the cost constraints. -
clientPattern
: A regex pattern to select specific clients for sending the transactions, targeting appropriate network nodes. -
excludeClientPattern
: A regex pattern to exclude certain clients from sending transactions, optimizing network interactions. -
awaitReceipt
: When enabled, the task waits for a receipt for each transaction, confirming execution on the network. -
failOnReject
: Determines if the task should fail upon transaction rejection, enhancing error handling.
Default settings for the generate_consolidations
task:
- name: generate_consolidations
config:
limitPerSlot: 0
limitTotal: 0
limitPending: 0
sourceMnemonic: ""
sourceStartIndex: 0
sourceStartValidatorIndex: null
sourceIndexCount: 0
targetValidatorIndex: null
targetPublicKey: ""
consolidationEpoch: null
walletPrivkey: ""
consolidationContract: 0x00431F263cE400f4455c2dCf564e53007Ca4bbBb
txAmount: "500000000000000000"
txFeeCap: "100000000000"
txTipCap: "1000000000"
txGasLimit: 100000
clientPattern: ""
excludeClientPattern: ""
awaitReceipt: false
failOnReject: false
consolidationTransactionsResultVar: ""
consolidationReceiptsResultVar: ""
The generate_deposits
task focuses on creating deposit transactions and sending them to the network. This task is crucial for testing how the network handles new deposits.
-
limitPerSlot
:
The maximum number of deposit transactions to be generated for each slot. -
limitTotal
:
The total limit on the number of deposit transactions that this task will generate. -
limitPending
:
The limit based on the number of pending deposit transactions. -
mnemonic
:
A mnemonic phrase used to generate validator keys. These keys are essential for creating valid deposit transactions. -
startIndex
:
The starting index within the mnemonic for generating validator keys. This defines the beginning point for the key generation process. -
indexCount
:
The total number of validator keys to generate from the mnemonic. This number determines how many unique deposit transactions will be created. -
publicKey
The publickey of the validator to generate a deposit for. This is for topup deposits only. -
walletPrivkey
:
The private key of the wallet from which the deposit will be made. This key is crucial for initiating the deposit transaction. -
depositContract
:
The address of the deposit contract on the blockchain. This is the destination where the deposit transactions will be sent. -
depositAmount
: The amount in ETH to be deposited for each transaction. This setting specifies the stake amount per validator being registered. -
depositTxFeeCap
:
The maximum fee cap for each deposit transaction. This limits the transaction fees for deposit operations. -
depositTxTipCap
:
The maximum tip cap for each deposit transaction. This controls the tip or priority fee for each transaction. -
withdrawalCredentials
:
Specifies the withdrawal credentials for the deposited ETH. If left empty, it defaults to a standard0x00...
credentials based on the validator mnemonic. -
topUpDeposit
:
Specifies if the deposit should be a topup deposit (without withdrawal credentials or signature) -
clientPattern
:
A regex pattern to select specific client endpoints for sending deposit transactions. If left blank, any available endpoint will be used. -
excludeClientPattern
:
A regex pattern to exclude certain clients from being used for deposit transactions. This parameter adds an extra layer of control over client selection. -
awaitReceipt
:
If set totrue
, the task waits for a receipt for each deposit transaction, ensuring they are confirmed on the network. -
failOnReject
:
Determines whether the task should fail if any deposit transaction is rejected by the network. -
depositTransactionsResultVar
:
The variable where the hashes of the generated deposit transactions will be stored. -
depositReceiptsResultVar
:
The variable for storing the receipts of the deposit transactions, applicable ifawaitReceipt
istrue
. -
validatorPubkeysResultVar
:
The variable where the public keys of the validators associated with the generated deposits will be stored.
Default settings for the generate_deposits
task:
- name: generate_deposits
config:
limitPerSlot: 0
limitTotal: 0
limitPending: 0
mnemonic: ""
startIndex: 0
indexCount: 0
publicKey: ""
walletPrivkey: ""
depositContract: ""
depositAmount: 32
depositTxFeeCap: 100000000000
depositTxTipCap: 1000000000
withdrawalCredentials: ""
topUpDeposit: false
clientPattern: ""
excludeClientPattern: ""
awaitReceipt: false
failOnReject: false
depositTransactionsResultVar: ""
depositReceiptsResultVar: ""
validatorPubkeysResultVar: ""
The generate_eoa_transactions
task creates and sends standard transactions from End-User Owned Accounts (EOAs) to the network, essential for testing regular transaction processing.
The task is intended for mass transaction generation.
-
limitPerBlock
:
The maximum number of transactions to generate per block. -
limitTotal
:
The total limit on the number of transactions to be generated. -
limitPending
:
The limit based on the number of pending transactions. -
privateKey
:
The private key of the main wallet. -
childWallets
:
The number of child wallets to be created and funded. (If 0, send blob transactions directly from privateKey wallet) -
walletSeed
:
The seed phrase used for generating child wallets. (Will be used in combination with privateKey to generate unique child wallets that do not collide with other tasks) -
refillPendingLimit
:
The maximum number of pending refill transactions allowed. This limit is used to control the refill process for child wallets, ensuring that the number of refill transactions does not exceed this threshold. -
refillFeeCap
:
The maximum fee cap for refilling transactions. -
refillTipCap
:
The maximum tip cap for refill transactions. -
refillAmount
:
The amount to refill in each child wallet. -
refillMinBalance
:
The minimum balance required before triggering a refill. -
legacyTxType
:
Determines whether to use the legacy type for transactions. -
feeCap
:
The maximum fee cap for transactions. -
tipCap
:
The tip cap for transactions. -
gasLimit
:
The gas limit for each transaction. -
targetAddress
:
The target address for transactions. -
randomTarget
:
If true, transactions are sent to random addresses. -
contractDeployment
:
Determines whether the transactions are for contract deployment. -
callData
:
Call data included in the transactions. -
randomAmount
:
If true, the transaction amount is randomized. -
amount
:
The amount of ETH (in wei) to be sent in each transaction. -
awaitReceipt
:
Iffalse
, the task succeeds immediately after sending the transactions without waiting for the receipts. Iftrue
, it waits for all receipts. -
failOnReject
:
Iftrue
, the task fails if any transaction is rejected. -
failOnSuccess
:
Iftrue
, the task fails if any transaction is successful and not rejected. -
clientPattern
:
A regex pattern for selecting specific client endpoints for sending the transactions. This allows targeting particular clients or groups for transaction dispatch. -
excludeClientPattern
:
A regex pattern to exclude certain client endpoints from being used to send the transactions. This feature provides an additional layer of control by allowing the exclusion of specific clients, which can be useful for testing under various network scenarios.
Default settings for the generate_eoa_transactions
task:
- name: generate_eoa_transactions
config:
limitPerBlock: 0
limitTotal: 0
limitPending: 0
privateKey: ""
childWallets: 0
walletSeed: ""
refillPendingLimit: 200
refillFeeCap: "500000000000"
refillTipCap: "1000000000"
refillAmount: "1000000000000000000"
refillMinBalance: "500000000000000000"
legacyTxType: false
feeCap: "100000000000"
tipCap: "1000000000"
gasLimit: 50000
targetAddress: ""
randomTarget: false
contractDeployment: false
callData: ""
randomAmount: false
amount: "0"
awaitReceipt: false
failOnReject: false
failOnSuccess: false
clientPattern: ""
excludeClientPattern: ""
The generate_exits
task is designed to create and send voluntary exit transactions to the network. This task is essential for testing how the network handles the process of validators voluntarily exiting from their responsibilities.
-
limitPerSlot
:
The maximum number of exit transactions to generate per slot. -
limitTotal
:
The total limit on the number of exit transactions that the task will generate. -
mnemonic
:
A mnemonic phrase used for generating the validators' keys involved in the exit transactions. -
startIndex
:
The starting index within the mnemonic from which to begin generating validator keys. This sets the initial point for key generation. -
indexCount
:
The number of validator keys to generate from the mnemonic, determining how many unique exit transactions will be created. -
exitEpoch
:
The exit epoch number set within the exit message. (defaults to head epoch) -
clientPattern
:
A regex pattern for selecting specific client endpoints for sending the exit transactions. If left empty, any available endpoint will be used. -
excludeClientPattern
:
A regex pattern to exclude certain client endpoints from being used for exit transactions. This parameter adds a layer of control by allowing the exclusion of specific clients, which can be useful for testing under various network scenarios.
Default settings for the generate_exits
task:
- name: generate_exits
config:
limitPerSlot: 0
limitTotal: 0
mnemonic: ""
startIndex: 0
indexCount: 0
exitEpoch: -1
clientPattern: ""
excludeClientPattern: ""
The generate_slashings
task is designed to create slashing operations for artificially constructed slashable conditions, and send these operations to the network.
It's important to note that while the slashing operations are sent to the network, the fake attestations or proposals that justify these slashings are never actually broadcasted. This task is vital for testing the network's response to validator misconduct without affecting the actual network operations.
-
slashingType
:
Determines the type of slashing to be simulated. Options areattester
for attestations-related slashing andproposer
for proposal-related slashing.
This setting decides the kind of validator misbehavior being simulated. -
limitPerSlot
:
The maximum number of slashing operations to generate per slot. -
limitTotal
:
The total limit on the number of slashing operations to be generated by this task. -
mnemonic
:
A mnemonic phrase for generating the keys of validators involved in the simulated slashing. -
startIndex
:
The index from which to start generating validator keys within the mnemonic sequence. -
indexCount
:
The number of validator keys to generate from the mnemonic, indicating how many distinct slashing operations will be created.-
clientPattern
:
A regex pattern for selecting specific client endpoints to send the slashing operations. If not specified, the task will use any available endpoint.
-
-
excludeClientPattern
: A regex pattern to exclude certain clients from being used for slashing operations. This feature provides an additional layer of control by allowing the exclusion of specific clients, which can be useful for testing under various network conditions.
Default settings for the generate_slashings
task:
- name: generate_slashings
config:
slashingType: attester
limitPerSlot: 0
limitTotal: 0
mnemonic: ""
startIndex: 0
indexCount: 0
clientPattern: ""
excludeClientPattern: ""
The generate_transaction
task creates and sends a single transaction to the network and optionally checks the transaction receipt. This task is useful for testing specific transaction behaviors, including contract deployments, and verifying receipt properties like triggered events.
-
privateKey
:
The private key used for generating the transaction. -
legacyTxType
:
Iftrue
, generates a legacy (type 0) transaction. Iffalse
, a dynamic fee (type 2) transaction is created. -
blobTxType
:
Iftrue
, generates a blob (type 3) transaction. Otherwise, a dynamic fee (type 2) transaction is used. -
setCodeTxType
:
Iftrue
, generates a set code (type 4) transaction. Otherwise, a dynamic fee (type 2) transaction is used. -
blobFeeCap
:
The fee cap for blob transactions. Used only ifblobTxType
istrue
. -
feeCap
:
The maximum fee cap for the transaction. -
tipCap
:
The tip cap for the transaction. -
gasLimit
:
The gas limit for the transaction. -
targetAddress
:
The target address for the transaction. -
randomTarget
:
Iftrue
, the transaction is sent to a random address. -
contractDeployment
:
Iftrue
, the transaction is for deploying a contract. -
callData
:
Call data included in the transaction. -
blobData
:
Data for the blob component of the transaction. Used only ifblobTxType
istrue
. -
authorizations
:
EOA code authorizations. Used only ifsetCodeTxType
istrue
.- { "chainId": 0, "nonce": null, "codeAddress": "0x000...", "signerPrivkey": "000..." }
-
randomAmount
:
Iftrue
, the transaction amount is randomized. -
amount
:
The amount of cryptocurrency to be sent in the transaction. -
nonce
:
The nonce for the transaction. If not set, the nonce is incremented by 1. -
clientPattern
:
A regex pattern to select specific client endpoints for sending the transaction. -
excludeClientPattern
:
A regex pattern to exclude certain clients from being used for sending the transaction. -
awaitReceipt
:
Iffalse
, the task succeeds immediately after sending the transaction without waiting for the receipt. Iftrue
, it waits for the receipt. -
failOnReject
:
Iftrue
, the task fails if the transaction is rejected. -
failOnSuccess
:
Iftrue
, the task fails if the transaction is successful and not rejected. -
expectEvents
:
A list of events that the transaction is expected to trigger, specified in a structured object format. Each event object can have the following properties:topic0
,topic1
,topic2
,topic3
, anddata
. All these properties are optional and expressed as hexadecimal strings (e.g., "0x000..."). The task checks all triggered events against these objects and looks for a match that satisfies all specified properties in any single event. An example event object might look like this:- { "topic0": "0x000...", "topic1": "0x000...", "topic2": "0x000...", "topic3": "0x000...", "data": "0x000..." }
-
transactionHashResultVar
:
The variable name to store the transaction hash, available for use by subsequent tasks. -
transactionReceiptResultVar
:
The variable name to store the full transaction receipt, available for use by subsequent tasks. -
contractAddressResultVar
:
The variable name to store the deployed contract address if the transaction was a contract deployment, available for use by subsequent tasks.
Default settings for the generate_transaction
task:
- name: generate_transaction
config:
privateKey: ""
legacyTxType: false
blobTxType: false
setCodeTxType: false
blobFeeCap: null
feeCap: "100000000000"
tipCap: "1000000000"
gasLimit: 50000
targetAddress: ""
randomTarget: false
contractDeployment: false
callData: ""
blobData: ""
authorizations: []
randomAmount: false
amount: "0"
nonce: null
clientPattern: ""
excludeClientPattern: ""
awaitReceipt: true
failOnReject: false
failOnSuccess: false
expectEvents: []
transactionHashResultVar: ""
transactionReceiptResultVar: ""
contractAddressResultVar: ""
The generate_withdrawal_requests
task facilitates the generation and submission of withdrawal requests to the Ethereum network. This task is crucial for simulating the process of withdrawing funds or exiting validators as part of execution layer triggered staking operations.
The source validators can be specified in three ways:
- By providing
sourcePubkey
, which is used as static pubkey for all requests - By providing
sourceMnemonic
,sourceStartIndex
&sourceIndexCount
to select the source validators by the pubkeys derived from the mnemonic & key range - By providing
sourceStartValidatorIndex
&sourceIndexCount
to select the source validators by their validator index
-
limitPerSlot
: Specifies the maximum number of withdrawal requests allowed per slot, managing network load and ensuring efficient processing. -
limitTotal
: Sets an upper limit on the total number of withdrawal requests that can be generated by this task. -
limitPending
: Defines the maximum number of pending withdrawal requests allowed at any given time. -
sourcePubkey
: The static pubkey to include in the withdrawal requests. -
sourceMnemonic
: The mnemonic used to derive source validator keys from which withdrawals will be requested. -
sourceStartIndex
: The starting index for key derivation from the source mnemonic. -
sourceStartValidatorIndex
: An alternative to usingsourceMnemonic
andsourceStartIndex
, this directly specifies the starting validator index for withdrawal requests. -
sourceIndexCount
: The number of validators to include in the withdrawal process from the specified starting index. -
withdrawAmount
: The amount in gwei to be withdrawn per request. Setting this to0
triggers a full exit for the validator. -
walletPrivkey
: The private key of the wallet initiating the withdrawal requests, necessary for transaction authorization. -
withdrawalContract
: The address of the smart contract that handles the withdrawal requests on the blockchain. -
txAmount
,txFeeCap
,txTipCap
,txGasLimit
: Transaction parameters including the amount to be transferred, fee cap, tip cap, and gas limit, which dictate the economic aspects of the withdrawal transactions. -
clientPattern
,excludeClientPattern
: Regular expressions for selecting or excluding specific client endpoints for sending the withdrawal requests. -
awaitReceipt
: Specifies whether to wait for a receipt confirmation for each transaction, confirming execution on the network. -
failOnReject
: Determines if the task should fail upon transaction rejection, enhancing error handling and response strategies.
-
transactionHashes
: A list of hashes for the transactions that have been sent. This output provides identifiers for tracking the transactions on the blockchain. -
transactionReceipts
: IfawaitReceipt
is true, this will include the receipts for each transaction, providing details such as success status, gas used, and potentially logs if applicable.
Default settings for the generate_withdrawal_requests
task:
- name: generate_withdrawal_requests
config:
limitPerSlot: 0
limitTotal: 0
limitPending: 0
sourcePubkey: ""
sourceMnemonic: ""
sourceStartIndex: 0
sourceStartValidatorIndex: null
sourceIndexCount: 0
withdrawAmount: 0
walletPrivkey: ""
withdrawalContract: 0x0c15F14308530b7CDB8460094BbB9cC28b9AaaAA
txAmount: "500000000000000000"
txFeeCap: "100000000000"
txTipCap: "1000000000"
txGasLimit: 200000
clientPattern: ""
excludeClientPattern: ""
awaitReceipt: false
failOnReject: false
```## `get_consensus_specs` Task
### Description
The `get_consensus_specs` task retrieves the specifications of the consensus chain. This task is crucial for understanding the current parameters and configurations that govern the consensus layer of the Ethereum network.
### Configuration Parameters
This task does not require any specific configuration parameters. It is designed to fetch the consensus chain specifications directly without the need for additional settings.
### Outputs
- **`specs`**:
This output includes all the specification values of the consensus chain. It provides a comprehensive overview of the network's current operational parameters, such as epoch lengths, reward amounts, slashing penalties, and other critical consensus metrics.
### Defaults
Default settings for the `get_consensus_specs` task:
```yaml
- name: get_consensus_specs
config: {}
The get_execution_block
task is designed to retrieve the most recent block on the chain. This information can be crucial for various purposes, such as tracking chain progress, verifying transactions, or inspecting the block.
-
header
: The result of theeth_getBlockByNumber
call, returning the block headers.
Default settings for the get_execution_block
task:
- name: get_execution_block
id: "get_head_block"
title: "Check head block and block hash from EL RPC"
timeout: 5m
```## `get_pubkeys_from_mnemonic` Task
### Description
The `get_pubkeys_from_mnemonic` task generates public keys from a given mnemonic phrase. This task is essential for setting up and verifying validator identities in scenarios involving multiple validators derived from a single mnemonic, commonly used in Ethereum staking operations.
### Configuration Parameters
- **`mnemonic`**:
The mnemonic phrase used to generate the public keys. This should be a BIP-39 compliant seed phrase that is used to derive Ethereum validator keys.
- **`startIndex`**:
The starting index from which to begin deriving public keys. This allows users to specify a segment of the key sequence for generation, rather than starting from the beginning.
- **`count`**:
The number of public keys to generate from the specified `startIndex`.
### Outputs
- **`pubkeys`**:
A list of validator public keys derived from the mnemonic. Each key corresponds to a validator index starting from the `startIndex` and continuing for `count` keys. This output is crucial for tasks that involve setting up validators, validating identities, or performing any operation that requires public key data.
### Defaults
Default settings for the `get_pubkeys_from_mnemonic` task:
```yaml
- name: get_pubkeys_from_mnemonic
config:
mnemonic: ""
startIndex: 0
count: 1
The get_random_mnemonic
task is designed to create a random mnemonic phrase. This task is particularly useful in scenarios where generating new wallets or accounts is necessary for testing purposes. A mnemonic phrase, often used in cryptocurrency wallets, is a set of words that can be translated into a binary seed, which in turn can be used to generate wallet addresses.
-
mnemonicResultVar
: The name of the variable where the generated mnemonic will be stored. This allows the mnemonic to be used in subsequent tasks, enabling the dynamic creation of wallets or accounts based on the mnemonic.
Default settings for the get_random_mnemonic
task:
- name: get_random_mnemonic
config:
mnemonicResultVar: ""
The get_wallet_details
task retrieves detailed information about a wallet on the Ethereum blockchain. It is instrumental for validating wallet configurations and assessing their current states within various testing and operational environments.
-
privateKey
: The private key of the wallet for which details are sought. If the private key is provided, the address will be derived from it and does not need to be separately specified. -
address
: The public address of the wallet. Specify this if you want to query the blockchain for wallet details without providing the private key. Either theprivateKey
or theaddress
can be specified, but not both.
The get_wallet_details
task provides the following outputs after execution:
-
address
: The public address of the wallet, either derived from the provided private key or as directly specified. -
balance
: The current balance of the wallet in wei, offering insight into the funds available at the time of the query. -
nonce
: The transaction count or nonce of the wallet, indicating the number of transactions sent from the wallet's address. This is essential for tracking the wallet's activity and sequence. -
summary
: A comprehensive summary of all wallet properties. This summary encapsulates the wallet's address, balance, nonce, and other pertinent details, providing a complete overview of the wallet's status.
Default settings for the get_wallet_details
task:
- name: get_wallet_details
config:
privateKey: ""
address: ""
```## `run_command` Task
### Description
The `run_command` task is designed to execute a specified shell command. This task is useful for integrating external scripts or commands into the testing workflow.
### Configuration Parameters
- **`allowed_to_fail`**:
Determines the task's behavior in response to the command's exit status. If set to `false`, the task will not fail even if the command exits with a failure code. This is useful for commands where a non-zero exit status does not necessarily indicate a critical problem.
- **`command`**:
The command to be executed, along with its arguments. This should be provided as an array, where the first element is the command and subsequent elements are the arguments. For example, to list files in the current directory with detailed information, you would use `["ls", "-la", "."]`.
### Defaults
Default settings for the `run_command` task:
```yaml
- name: run_command
config:
allowed_to_fail: false
command: []
The run_external_tasks
task is designed to execute a set of tasks specified in an external test playbook. This functionality is key for integrating modular and reusable test configurations that are maintained outside the primary Assertoor configuration file.
-
testFile
:
The path to the external test playbook file. This file contains the configuration for the tasks to be executed, including task definitions and any specific settings required for those tasks. -
testConfig
:
A dictionary of static configuration parameters that are passed to the external test playbook. These configurations are used to customize or override settings within the external test playbook. -
testConfigVars
:
A dictionary of dynamic variable expressions that are evaluated and also passed to the external test playbook. -
expectFailure
:
A boolean that specifies whether the task is expected to fail. If set totrue
, the task will be considered successful if the external tasks fail. -
ignoreFailure
:
A boolean that indicates whether failures in the external tasks should be ignored. Iftrue
, therun_external_tasks
task will report success regardless of any failures that occur during the execution of the external tasks. This can be useful when the outcomes of the tasks are not critical to the overall test objectives.
Default settings for the run_external_tasks
task:
- name: run_external_tasks
config:
testFile: ""
testConfig: {}
testConfigVars: {}
expectFailure: false
ignoreFailure: false
The run_shell
task executes a series of commands within a shell environment. This task is especially useful for complex operations that require executing a shell script or a sequence of commands within a specific shell.
-
shell
:
Specifies the type of shell to use for running the commands. Common shells includesh
,bash
,zsh
, etc. The default issh
. -
shellArgs
:
Additional arguments to pass to the shell. Example:--login
. -
envVars
:
A dictionary specifying the environment variables to be used within the shell. Each key in this dictionary represents the name of an environment variable, and its corresponding value indicates the name of a variable from which the actual value should be read.
For instance, ifenvVars
is set as{"PATH_VAR": "MY_PATH", "USER_VAR": "MY_USER"}
, the task will use the values ofMY_PATH
andMY_USER
variables from the current task variable context as the values forPATH_VAR
andUSER_VAR
within the shell. -
command
:
The command or series of commands to be executed in the shell. This can be a single command or a full script. The commands should be provided as a single string, and if multiple commands are needed, they can be separated by the appropriate shell command separator (e.g., newlines or semicolons insh
orbash
).
The run_shell
task scans the standard output (stdout) of the shell script for specific triggers that enable actions from within the script.
For instance, a script can set a variable in the current task context by outputting a formatted string.
An example of setting a variable USER_VAR
to "new value" would be:
echo "::set-var USER_VAR new value"
This feature allows the shell script to interact dynamically with the task context, modifying variables based on script execution.
Please note that this feature is still under development and the format of these triggers may change in future versions of the tool. It's important to stay updated with the latest documentation and release notes for any modifications to this functionality.
Default settings for the run_shell
task:
- name: run_shell
config:
shell: bash
shellArgs: []
envVars: {}
command: ""
The run_task_background
task facilitates the concurrent execution of a foreground task and a background task, with configurable dependencies and outcomes. This task is essential for simulating complex scenarios involving parallel processes.
- The task initiates both the foreground and background tasks simultaneously.
- It continuously monitors the status and result of both tasks.
- Upon completion of the foreground task, the
run_task_background
task also completes, and the background task is cancelled if it's still running. - The result of the
run_task_background
task mirrors the result of the foreground task. For instance, if the foreground task updates its result to "success", therun_task_background
task will also set its result to "success". - The behavior following the completion of the background task is configurable based on the
onBackgroundComplete
setting.
-
foregroundTask
:
The task that runs in the foreground. This is the primary task and is defined as per the standard task definition format. -
backgroundTask
:
The task that runs in the background concurrently with the foreground task. It is also defined following the standard task definition format. -
exitOnForegroundSuccess
:
If set totrue
, therun_task_background
task will exit with a success result when the foreground task's result is set to "success". Note that this does not necessarily mean the foreground task has completed. If still running, both the background and foreground tasks will be cancelled. -
exitOnForegroundFailure
:
Iftrue
, the task exits with a failure result when the foreground task's result is set to "failure". This does not imply the foreground task's completion. Both the background and foreground tasks will be cancelled if they are still running. -
onBackgroundComplete
:
Specifies the action to take when the background task completes. Options are:-
ignore
: No action is taken. -
fail
: Exits the task with a failure result. -
succeed
: Exits the task with a success result. -
failOrIgnore
: Exits with a failure result if the background task fails, otherwise no action is taken.
-
-
newVariableScope
:
Determines if a new variable scope should be created for the foreground task. Iffalse
, the current scope is passed through. The background task always operates in a new variable scope, which inherits from the parent but does not propagate changes upwards.
Default settings for the run_task_background
task:
- name: run_task_background
config:
foregroundTask: {}
backgroundTask: {}
exitOnForegroundSuccess: false
exitOnForegroundFailure: false
onBackgroundComplete: "ignore"
newVariableScope: false
The run_task_matrix
task is designed to execute a specified task multiple times, each with different input values drawn from an array. This task is ideal for scenarios where you need to test a task under various conditions or with different sets of data.
-
runConcurrent
:
Determines whether the child tasks (instances of the task being run for each matrix value) should run concurrently or sequentially. Iftrue
, all tasks run at the same time; iffalse
, they run one after the other. -
succeedTaskCount
:
The number of child tasks that need to succeed (result status "success") for therun_task_matrix
task to stop and return a success result. A value of 0 means all child tasks need to succeed for the overall task to be considered successful. -
failTaskCount
:
The number of child tasks that may to fail (result status "failure") before therun_task_matrix
task to stops and returns a failure result. A value of 0 means that the appearance of any failure in child tasks will cause the overall task to fail. -
matrixValues
:
An array of values that form the matrix. Each value in this array is used to run the child task with a different input. -
matrixVar
:
The name of the variable to which the current matrix value is assigned for each child task. This allows the child task to access and use the specific value from the matrix. -
task
:
The definition of the task to be executed for each matrix value. This task is run repeatedly, once for each value in thematrixValues
array, with the current value made accessible via the variable named inmatrixVar
.
Default settings for the run_task_matrix
task:
- name: run_task_matrix
config:
runConcurrent: false
succeedTaskCount: 0
failTaskCount: 0
matrixValues: []
matrixVar: ""
task: {}
The run_task_options
task is designed to execute a single task with configurable behaviors and response actions. This flexibility allows for precise control over how the task's outcome is handled and how it interacts with the overall test environment.
-
task
:
The task to be executed. This is defined following the standard task definition format. -
propagateResult
:
This setting controls how the result of the child task influences the result of therun_task_options
task. If set totrue
, any change in the result of the child task (success or failure) is immediately reflected in the result of the parentrun_task_options
task. Iffalse
, the child task's result is only propagated to the parent task after the child task has completed its execution. -
exitOnResult
:
If set totrue
, the task will cancel the child task as soon as it sets a result, whether it is "success" or "failure." This option is useful for scenarios where immediate response to the child task's result is necessary. -
invertResult
:
Whentrue
, the result of the child task is inverted. This means therun_task_options
task will fail if the child task succeeds and succeed if the child task fails. This can be used to validate negative test scenarios. -
expectFailure
:
If set totrue
, this option expects the child task to fail. Therun_task_options
task will fail if the child task does not end with a "failure" result, ensuring that failure scenarios are handled as expected. -
ignoreFailure
:
Whentrue
, any failure result from the child task is ignored, and therun_task_options
task will return a success result instead. This is useful for cases where the child task's failure is an acceptable outcome. -
retryOnFailure
:
If set totrue
, the task will retry the execution of the child task if it fails, up to the maximum number of retries specified bymaxRetryCount
. -
maxRetryCount
:
The maximum number of times the child task will be retried if it fails andretryOnFailure
is true. A value of 0 means no retries. -
newVariableScope
:
Determines whether to create a new variable scope for the child task. Iffalse
, the current scope is passed through, allowing the child task to share the same variable context as therun_task_options
task.
Default settings for the run_task_options
task:
- name: run_task_options
config:
task: null
propagateResult: false
exitOnResult: false
invertResult: false
expectFailure: false
ignoreFailure: false
retryOnFailure: false
maxRetryCount: 0
newVariableScope: false
The run_tasks
task executes a series of specified tasks sequentially. This is particularly useful for scenarios where tasks need to be performed in a specific order, with the outcome of one potentially affecting the subsequent ones.
- The task starts the child tasks one after the other in the order they are listed.
- It continuously monitors the result of the currently running child task. As soon as the child task returns a "success" or "failure" result, the execution of that task is stopped.
- After cancelling the current task, the
run_tasks
task then initiates the next task in the sequence.
An important aspect of this task is that it cancels tasks once they return a result. This is particularly significant for check tasks, which, by their nature, would continue running indefinitely according to their logic. In this sequential setup, however, they are stopped once they achieve a result, allowing the sequence to proceed.
-
tasks
:
An array of tasks to be executed one after the other. Each task is defined according to the standard task structure. -
stopChildOnResult
:
If set totrue
, each child task in the sequence is stopped as soon as it sets a result (either "success" or "failure"). This ensures that once a task has reached a outcome, it does not continue to run unnecessarily, allowing the next task in the sequence to commence. -
expectFailure
:
If set totrue
, this option expects each task in the sequence to fail. The task sequence stops with a "failure" result if any task does not fail as expected. -
continueOnFailure
:
Whentrue
, the sequence of tasks continues even if individual tasks fail, allowing the entire sequence to be executed regardless of individual task outcomes. -
newVariableScope
:
Determines whether to create a new variable scope for the child tasks. Iffalse
, the current scope is passed through, allowing the child tasks to share the same variable context as therun_tasks
task.
Default settings for the run_tasks
task:
- name: run_tasks
config:
tasks: []
stopChildOnResult: true
expectFailure: false
continueOnFailure: false
newVariableScope: false
The run_tasks_concurrent
task allows for the parallel execution of multiple tasks. This task is crucial in scenarios where tasks need to be run simultaneously, such as in testing environments that require concurrent processes or operations.
-
succeedTaskCount
:
The minimum number of child tasks that need to complete with a "success" result for therun_tasks_concurrent
task to stop and return a success result. A value of 0 indicates that all child tasks need to succeed for the overall task to be considered successful. -
failTaskCount
:
The minimum number of child tasks that need to complete with a "failure" result for therun_tasks_concurrent
task to stop and return a failure result. A value of 1 means the overall task will fail as soon as one child task fails. -
newVariableScope
:
If set to true, a new variable scope will be created for the child tasks, if not, the child tasks will use the same variable scope as the parent task. -
tasks
:
An array of child tasks to be executed concurrently. Each task in this array should be defined according to the standard task structure.
Default settings for the run_tasks_concurrent
task:
- name: run_tasks_concurrent
config:
succeedTaskCount: 0
failTaskCount: 1
newVariableScope: true
tasks: []
The sleep
task is designed to introduce a pause or delay in the execution flow for a specified duration. This task is useful in scenarios where a time-based delay is necessary between operations, such as waiting for certain conditions to be met or simulating real-time interactions.
-
duration
:
The length of time for which the task should pause execution. The duration is specified in a time format (e.g., '5s' for five seconds, '1m' for one minute). A duration of '0s' means no delay.
Default settings for the sleep
task:
- name: sleep
config:
duration: 0s