eth2.0-specs/tests/formats/rewards/README.md

2.4 KiB

Rewards tests

All rewards deltas sub-functions are tested for each test case. There is no "change" factor, the rewards/penalties outputs are pure functions with just the pre-state as input. (See test condition documentation on how to run the tests.)

Deltas is defined as:

class Deltas(Container):
    rewards: List[uint64, VALIDATOR_REGISTRY_LIMIT]
    penalties: List[uint64, VALIDATOR_REGISTRY_LIMIT]

Test case format

meta.yaml

description: string    -- Optional description of test case, purely for debugging purposes.
                          Tests should use the directory name of the test case as identifier, not the description.

Note: No signature verification happens within rewards sub-functions. These tests can safely be run with or without BLS enabled.

pre.yaml

A YAML-encoded BeaconState, the state before running the rewards sub-function.

Also available as pre.ssz.

source_deltas.yaml

A YAML-encoded Deltas representing the rewards and penalties returned by the rewards the get_source_deltas function

Also available as source_deltas.ssz.

target_deltas.yaml

A YAML-encoded Deltas representing the rewards and penalties returned by the rewards the get_target_deltas function

Also available as target_deltas.ssz.

head_deltas.yaml

A YAML-encoded Deltas representing the rewards and penalties returned by the rewards the get_head_deltas function

Also available as head_deltas.ssz.

inclusion_delay_deltas.yaml

A YAML-encoded Deltas representing the rewards and penalties returned by the rewards the get_inclusion_delay_deltas function

Also available as inclusion_delay_deltas.ssz.

inactivity_penalty_deltas.yaml

A YAML-encoded Deltas representing the rewards and penalties returned by the rewards the get_inactivity_penalty_deltas function

Also available as inactivity_penalty_deltas.ssz.

Condition

A handler of the rewards test-runner should process these cases, calling the corresponding rewards deltas function for each set of deltas.

The provided pre-state is ready to be input into each rewards deltas function.

The provided deltas should match the return values of the deltas function. Specifically the following must hold true for each set of deltas:

    deltas.rewards == deltas_function(state)[0]
    deltas.penalties == deltas_function(state)[1]