2021-03-12 00:33:04 +08:00
# Fork choice tests
2021-03-12 22:13:07 +08:00
The aim of the fork choice tests is to provide test coverage of the various components of the fork choice.
2021-03-12 00:33:04 +08:00
2023-06-01 23:56:14 +08:00
## Table of contents
<!-- TOC -->
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
<!-- DON'T EDIT THIS SECTION, INSTEAD RE - RUN doctoc TO UPDATE -->
- [Test case format ](#test-case-format )
- [`meta.yaml` ](#metayaml )
- [`anchor_state.ssz_snappy` ](#anchor_statessz_snappy )
- [`anchor_block.ssz_snappy` ](#anchor_blockssz_snappy )
- [`steps.yaml` ](#stepsyaml )
- [`on_tick` execution step ](#on_tick-execution-step )
- [`on_attestation` execution step ](#on_attestation-execution-step )
- [`on_block` execution step ](#on_block-execution-step )
- [`on_merge_block` execution step ](#on_merge_block-execution-step )
- [`on_attester_slashing` execution step ](#on_attester_slashing-execution-step )
- [`on_payload_info` execution step ](#on_payload_info-execution-step )
- [Checks step ](#checks-step )
- [`attestation_<32-byte-root>.ssz_snappy` ](#attestation_32-byte-rootssz_snappy )
- [`block_<32-byte-root>.ssz_snappy` ](#block_32-byte-rootssz_snappy )
- [Condition ](#condition )
<!-- END doctoc generated TOC please keep comment here to allow auto update -->
<!-- /TOC -->
2021-03-12 00:33:04 +08:00
## Test case format
### `meta.yaml`
```yaml
description: string -- Optional. Description of test case, purely for debugging purposes.
bls_setting: int -- see general test-format spec.
```
### `anchor_state.ssz_snappy`
2021-03-12 20:40:29 +08:00
An SSZ-snappy encoded `BeaconState` , the state to initialize store with `get_forkchoice_store(anchor_state: BeaconState, anchor_block: BeaconBlock)` helper.
2021-03-12 00:33:04 +08:00
### `anchor_block.ssz_snappy`
2021-03-12 20:40:29 +08:00
An SSZ-snappy encoded `BeaconBlock` , the block to initialize store with `get_forkchoice_store(anchor_state: BeaconState, anchor_block: BeaconBlock)` helper.
2021-03-12 00:33:04 +08:00
### `steps.yaml`
The steps to execute in sequence. There may be multiple items of the following types:
#### `on_tick` execution step
The parameter that is required for executing `on_tick(store, time)` .
```yaml
2021-06-15 21:52:25 +08:00
{
2021-06-22 20:55:52 +08:00
tick: int -- to execute `on_tick(store, time)` .
2021-06-19 02:13:02 +08:00
valid: bool -- optional, default to `true` .
If it's `false` , this execution step is expected to be invalid.
2021-06-15 21:52:25 +08:00
}
2021-03-12 00:33:04 +08:00
```
After this step, the `store` object may have been updated.
#### `on_attestation` execution step
The parameter that is required for executing `on_attestation(store, attestation)` .
```yaml
2021-06-15 21:52:25 +08:00
{
attestation: string -- the name of the `attestation_<32-byte-root>.ssz_snappy` file.
To execute `on_attestation(store, attestation)` with the given attestation.
2021-06-19 02:13:02 +08:00
valid: bool -- optional, default to `true` .
If it's `false` , this execution step is expected to be invalid.
2021-06-15 21:52:25 +08:00
}
2021-03-12 00:33:04 +08:00
```
The file is located in the same folder (see below).
After this step, the `store` object may have been updated.
#### `on_block` execution step
The parameter that is required for executing `on_block(store, block)` .
```yaml
2021-06-15 21:52:25 +08:00
{
2023-06-01 23:56:14 +08:00
block: string -- the name of the `block_<32-byte-root>.ssz_snappy` file.
To execute `on_block(store, block)` with the given attestation.
2023-07-31 19:47:53 +08:00
blobs: string -- optional, the name of the `blobs_<32-byte-root>.ssz_snappy` file.
2023-06-01 23:56:14 +08:00
The blobs file content is a `List[Blob, MAX_BLOBS_PER_BLOCK]` SSZ object.
proofs: array of byte48 hex string -- optional, the proofs of blob commitments.
valid: bool -- optional, default to `true` .
If it's `false` , this execution step is expected to be invalid.
2021-06-15 21:52:25 +08:00
}
2021-03-12 00:33:04 +08:00
```
2023-06-01 23:56:14 +08:00
2021-03-12 00:33:04 +08:00
The file is located in the same folder (see below).
2023-07-31 19:47:53 +08:00
`blobs` and `proofs` are new fields from Deneb EIP-4844. These fields indicate the expected values from `retrieve_blobs_and_proofs()` helper inside `is_data_available()` helper. If these two fields are not provided, `retrieve_blobs_and_proofs()` returns empty lists.
2023-06-01 23:56:14 +08:00
2021-03-12 00:33:04 +08:00
After this step, the `store` object may have been updated.
2022-08-03 18:19:39 +06:00
#### `on_merge_block` execution step
2021-09-23 23:10:29 +03:00
2021-09-24 21:06:02 +03:00
Adds `PowBlock` data which is required for executing `on_block(store, block)` .
```yaml
{
pow_block: string -- the name of the `pow_block_<32-byte-root>.ssz_snappy` file.
To be used in `get_pow_block` lookup
2022-03-09 10:18:00 +08:00
}
2021-09-24 21:06:02 +03:00
```
The file is located in the same folder (see below).
2021-09-23 23:10:29 +03:00
PowBlocks should be used as return values for `get_pow_block(hash: Hash32) -> PowBlock` function if hashes match.
2022-03-09 10:18:00 +08:00
#### `on_attester_slashing` execution step
The parameter that is required for executing `on_attester_slashing(store, attester_slashing)` .
```yaml
{
attester_slashing: string -- the name of the `attester_slashing_<32-byte-root>.ssz_snappy` file.
To execute `on_attester_slashing(store, attester_slashing)` with the given attester slashing.
valid: bool -- optional, default to `true` .
If it's `false` , this execution step is expected to be invalid.
}
```
The file is located in the same folder (see below).
After this step, the `store` object may have been updated.
2022-08-03 18:19:39 +06:00
#### `on_payload_info` execution step
Optional step for optimistic sync tests.
```yaml
{
block_hash: string, -- Encoded 32-byte value of payload's block hash.
payload_status: {
status: string, -- Enum, "VALID" | "INVALID" | "SYNCING" | "ACCEPTED" | "INVALID_BLOCK_HASH".
2022-08-24 23:29:59 +06:00
latest_valid_hash: string, -- Encoded 32-byte value of the latest valid block hash, may be `null` .
validation_error: string, -- Message providing additional details on the validation error, may be `null` .
2022-08-03 18:19:39 +06:00
}
}
```
2023-10-26 22:39:24 +08:00
This step sets the [`payloadStatus` ](https://github.com/ethereum/execution-apis/blob/main/src/engine/paris.md#payloadstatusv1 )
2022-08-03 18:19:39 +06:00
value that Execution Layer client mock returns in responses to the following Engine API calls:
2023-04-28 23:09:10 +08:00
* [`engine_newPayloadV1(payload)` ](https://github.com/ethereum/execution-apis/blob/main/src/engine/paris.md#engine_newpayloadv1 ) if `payload.blockHash == payload_info.block_hash`
* [`engine_forkchoiceUpdatedV1(forkchoiceState, ...)` ](https://github.com/ethereum/execution-apis/blob/main/src/engine/paris.md#engine_forkchoiceupdatedv1 ) if `forkchoiceState.headBlockHash == payload_info.block_hash`
2022-08-03 18:19:39 +06:00
*Note:* Status of a payload must be *initialized* via `on_payload_info` before the corresponding `on_block` execution step.
*Note:* Status of the same payload may be updated for several times throughout the test.
2021-03-12 00:33:04 +08:00
#### Checks step
2021-03-12 22:13:07 +08:00
The checks to verify the current status of `store` .
2021-03-12 00:33:04 +08:00
```yaml
2021-03-12 22:13:07 +08:00
checks: {< store_attibute > : value} -- the assertions.
2021-03-12 00:33:04 +08:00
```
2023-10-26 17:44:48 +11:00
`<store_attibute>` is the field member or property of [`Store` ](../../../specs/phase0/fork-choice.md#store ) object that maintained by client implementation. The fields include:
2021-03-12 00:33:04 +08:00
```yaml
2021-08-31 13:16:19 +08:00
head: {
slot: int,
root: string, -- Encoded 32-byte value from get_head(store)
}
time: int -- store.time
genesis_time: int -- store.genesis_time
justified_checkpoint: {
epoch: int, -- Integer value from store.justified_checkpoint.epoch
root: string, -- Encoded 32-byte value from store.justified_checkpoint.root
}
finalized_checkpoint: {
epoch: int, -- Integer value from store.finalized_checkpoint.epoch
root: string, -- Encoded 32-byte value from store.finalized_checkpoint.root
}
2021-11-24 00:09:48 +08:00
proposer_boost_root: string -- Encoded 32-byte value from store.proposer_boost_root
2023-10-26 17:44:48 +11:00
```
Additionally, these fields if `get_proposer_head` and `should_override_forkchoice_update` features are implemented:
```yaml
2023-10-26 22:39:24 +08:00
get_proposer_head: string -- Encoded 32-byte value from get_proposer_head(store)
should_override_forkchoice_update: { -- [New in Bellatrix]
validator_is_connected: bool, -- The mocking result of `validator_is_connected(proposer_index)` in this call
result: bool, -- The result of `should_override_forkchoice_update(store, head_root)` , where head_root is the result value from get_head(store)
}
2021-03-12 00:33:04 +08:00
```
For example:
```yaml
2021-03-12 22:13:07 +08:00
- checks:
2021-08-31 13:16:19 +08:00
time: 192
head: {slot: 32, root: '0xdaa1d49d57594ced0c35688a6da133abb086d191a2ebdfd736fad95299325aeb'}
justified_checkpoint: {epoch: 3, root: '0xc25faab4acab38d3560864ca01e4d5cc4dc2cd473da053fbc03c2669143a2de4'}
finalized_checkpoint: {epoch: 2, root: '0x40d32d6283ec11c53317a46808bc88f55657d93b95a1af920403187accf48f4f'}
2021-11-24 00:09:48 +08:00
proposer_boost_root: '0xdaa1d49d57594ced0c35688a6da133abb086d191a2ebdfd736fad95299325aeb'
2023-10-26 17:44:48 +11:00
get_proposer_head: '0xdaa1d49d57594ced0c35688a6da133abb086d191a2ebdfd736fad95299325aeb'
2023-10-26 22:39:24 +08:00
should_override_forkchoice_update: {validator_is_connected: false, result: false}
2021-03-12 00:33:04 +08:00
```
2021-03-12 22:13:07 +08:00
*Note*: Each `checks` step may include one or multiple items. Each item has to be checked against the current store.
2021-03-12 00:33:04 +08:00
### `attestation_<32-byte-root>.ssz_snappy`
`<32-byte-root>` is the hash tree root of the given attestation.
2021-03-12 20:40:29 +08:00
Each file is an SSZ-snappy encoded `Attestation` .
2021-03-12 00:33:04 +08:00
### `block_<32-byte-root>.ssz_snappy`
`<32-byte-root>` is the hash tree root of the given block.
2021-03-12 20:40:29 +08:00
Each file is an SSZ-snappy encoded `SignedBeaconBlock` .
2021-03-12 00:33:04 +08:00
## Condition
1. Deserialize `anchor_state.ssz_snappy` and `anchor_block.ssz_snappy` to initialize the local store object by with `get_forkchoice_store(anchor_state, anchor_block)` helper.
2021-03-12 20:40:29 +08:00
2. Iterate sequentially through `steps.yaml`
- For each execution, look up the corresponding ssz_snappy file. Execute the corresponding helper function on the current store.
2021-03-12 22:13:07 +08:00
- For the `on_block` execution step: if `len(block.message.body.attestations) > 0` , execute each attestation with `on_attestation(store, attestation)` after executing `on_block(store, block)` .
2021-03-12 20:40:29 +08:00
- For each `checks` step, the assertions on the current store must be satisfied.