1.6 KiB

Epoch processing tests

The different epoch sub-transitions are tested individually with test handlers. The format is similar to block-processing state-transition tests. There is no "change" factor however, the transitions are a pure functions with just the pre-state as input. Hence, the format is shared between each test-handler. (See test condition documentation on how to run the tests.)

Test case format

description: string    -- description of test case, purely for debugging purposes
bls_required: bool     -- optional, true if the test validity is strictly dependent on BLS being ON. False otherwise.
bls_ignored: bool      -- optional, true if the test validity is strictly dependent on BLS being OFF. False otherwise.
pre: BeaconState       -- state before running the sub-transition
post: BeaconState      -- state after applying the epoch sub-transition.

Note: if both bls_required and bls_ignored are false (or simply not included), then the test consumer can freely choose to run with BLS ON or OFF. One may choose for OFF for performance reasons during repeated testing. Otherwise it is recommended to run with BLS ON.

Condition

A handler of the epoch_processing test-runner should process these cases, calling the corresponding processing implementation.

Sub-transitions:

sub-transition-name processing call
crosslinks process_crosslinks(state)
registry_updates process_registry_updates(state)

The resulting state should match the expected post state.