mirror of
https://github.com/status-im/nimbus-eth2.git
synced 2025-01-09 05:52:45 +00:00
allow testing with custom cfg (#2884)
This extends some test utilities to allow simulating states that use a custom RuntimeConfig, e.g., to test with an earlier ALTAIR_FORK_EPOCH.
This commit is contained in:
parent
2ec34e6761
commit
4491259c52
@ -45,14 +45,17 @@ proc signMockBlock*(state: ForkedHashedBeaconState, b: var ForkedSignedBeaconBlo
|
|||||||
privkey).toValidatorSig()
|
privkey).toValidatorSig()
|
||||||
|
|
||||||
# https://github.com/ethereum/consensus-specs/blob/v1.1.0-beta.4/tests/core/pyspec/eth2spec/test/helpers/block.py#L75-L105
|
# https://github.com/ethereum/consensus-specs/blob/v1.1.0-beta.4/tests/core/pyspec/eth2spec/test/helpers/block.py#L75-L105
|
||||||
proc mockBlock*(state: ForkedHashedBeaconState, slot: Slot): ForkedSignedBeaconBlock =
|
proc mockBlock*(
|
||||||
|
state: ForkedHashedBeaconState,
|
||||||
|
slot: Slot,
|
||||||
|
cfg = defaultRuntimeConfig): ForkedSignedBeaconBlock =
|
||||||
## TODO don't do this gradual construction, for exception safety
|
## TODO don't do this gradual construction, for exception safety
|
||||||
## Mock a BeaconBlock for the specific slot
|
## Mock a BeaconBlock for the specific slot
|
||||||
|
|
||||||
var cache = StateCache()
|
var cache = StateCache()
|
||||||
var rewards = RewardInfo()
|
var rewards = RewardInfo()
|
||||||
var tmpState = assignClone(state)
|
var tmpState = assignClone(state)
|
||||||
doAssert process_slots(defaultRuntimeConfig, tmpState[], slot, cache, rewards, flags = {})
|
doAssert process_slots(cfg, tmpState[], slot, cache, rewards, flags = {})
|
||||||
|
|
||||||
var previous_block_header = getStateField(tmpState[], latest_block_header)
|
var previous_block_header = getStateField(tmpState[], latest_block_header)
|
||||||
if previous_block_header.state_root == ZERO_HASH:
|
if previous_block_header.state_root == ZERO_HASH:
|
||||||
|
@ -17,18 +17,14 @@ import
|
|||||||
./mock_deposits
|
./mock_deposits
|
||||||
|
|
||||||
proc initGenesisState*(
|
proc initGenesisState*(
|
||||||
num_validators: uint64 = 8'u64 * SLOTS_PER_EPOCH,
|
num_validators = 8'u64 * SLOTS_PER_EPOCH,
|
||||||
beaconStateFork: BeaconStateFork = forkPhase0): ref ForkedHashedBeaconState =
|
cfg = defaultRuntimeConfig): ref ForkedHashedBeaconState =
|
||||||
let deposits = mockGenesisBalancedDeposits(
|
let deposits = mockGenesisBalancedDeposits(
|
||||||
validatorCount = num_validators,
|
validatorCount = num_validators,
|
||||||
amountInEth = 32, # We create canonical validators with 32 Eth
|
amountInEth = 32, # We create canonical validators with 32 Eth
|
||||||
flags = {}
|
flags = {}
|
||||||
)
|
)
|
||||||
|
|
||||||
var cfg = defaultRuntimeConfig
|
|
||||||
if beaconStateFork >= forkAltair:
|
|
||||||
cfg.ALTAIR_FORK_EPOCH = GENESIS_EPOCH
|
|
||||||
|
|
||||||
result = (ref ForkedHashedBeaconState)(
|
result = (ref ForkedHashedBeaconState)(
|
||||||
beaconStateFork: forkPhase0,
|
beaconStateFork: forkPhase0,
|
||||||
hbsPhase0: initialize_hashed_beacon_state_from_eth1(
|
hbsPhase0: initialize_hashed_beacon_state_from_eth1(
|
||||||
@ -36,8 +32,6 @@ proc initGenesisState*(
|
|||||||
|
|
||||||
maybeUpgradeStateToAltair(cfg, result[])
|
maybeUpgradeStateToAltair(cfg, result[])
|
||||||
|
|
||||||
doAssert result.beaconStateFork == beaconStateFork
|
|
||||||
|
|
||||||
when isMainModule:
|
when isMainModule:
|
||||||
# Smoke test
|
# Smoke test
|
||||||
let state = initGenesisState(num_validators = SLOTS_PER_EPOCH)
|
let state = initGenesisState(num_validators = SLOTS_PER_EPOCH)
|
||||||
|
@ -36,7 +36,7 @@ func hackPrivKey*(v: Validator): ValidatorPrivKey =
|
|||||||
let i = int(uint64.fromBytesLE(bytes))
|
let i = int(uint64.fromBytesLE(bytes))
|
||||||
makeFakeValidatorPrivKey(i)
|
makeFakeValidatorPrivKey(i)
|
||||||
|
|
||||||
func makeDeposit*(i: int, flags: UpdateFlags = {}): DepositData =
|
func makeDeposit*(i: int, flags: UpdateFlags = {}, cfg = defaultRuntimeConfig): DepositData =
|
||||||
## Ugly hack for now: we stick the private key in withdrawal_credentials
|
## Ugly hack for now: we stick the private key in withdrawal_credentials
|
||||||
## which means we can repro private key and randao reveal from this data,
|
## which means we can repro private key and randao reveal from this data,
|
||||||
## for testing :)
|
## for testing :)
|
||||||
@ -51,13 +51,12 @@ func makeDeposit*(i: int, flags: UpdateFlags = {}): DepositData =
|
|||||||
amount: MAX_EFFECTIVE_BALANCE)
|
amount: MAX_EFFECTIVE_BALANCE)
|
||||||
|
|
||||||
if skipBLSValidation notin flags:
|
if skipBLSValidation notin flags:
|
||||||
result.signature = get_deposit_signature(
|
result.signature = get_deposit_signature(cfg, result, privkey).toValidatorSig()
|
||||||
defaultRuntimeConfig, result, privkey).toValidatorSig()
|
|
||||||
|
|
||||||
func makeInitialDeposits*(
|
func makeInitialDeposits*(
|
||||||
n = SLOTS_PER_EPOCH, flags: UpdateFlags = {}): seq[DepositData] =
|
n = SLOTS_PER_EPOCH, flags: UpdateFlags = {}, cfg = defaultRuntimeConfig): seq[DepositData] =
|
||||||
for i in 0..<n.int:
|
for i in 0..<n.int:
|
||||||
result.add makeDeposit(i, flags)
|
result.add makeDeposit(i, flags, cfg = cfg)
|
||||||
|
|
||||||
func signBlock(
|
func signBlock(
|
||||||
fork: Fork, genesis_validators_root: Eth2Digest, forked: ForkedBeaconBlock,
|
fork: Fork, genesis_validators_root: Eth2Digest, forked: ForkedBeaconBlock,
|
||||||
@ -82,13 +81,13 @@ proc addTestBlock*(
|
|||||||
deposits = newSeq[Deposit](),
|
deposits = newSeq[Deposit](),
|
||||||
graffiti = default(GraffitiBytes),
|
graffiti = default(GraffitiBytes),
|
||||||
flags: set[UpdateFlag] = {},
|
flags: set[UpdateFlag] = {},
|
||||||
nextSlot = true): ForkedSignedBeaconBlock =
|
nextSlot = true,
|
||||||
|
cfg = defaultRuntimeConfig): ForkedSignedBeaconBlock =
|
||||||
# Create and add a block to state - state will advance by one slot!
|
# Create and add a block to state - state will advance by one slot!
|
||||||
if nextSlot:
|
if nextSlot:
|
||||||
var rewards: RewardInfo
|
var rewards: RewardInfo
|
||||||
doAssert process_slots(
|
doAssert process_slots(
|
||||||
defaultRuntimeConfig, state, getStateField(state, slot) + 1, cache,
|
cfg, state, getStateField(state, slot) + 1, cache, rewards, flags)
|
||||||
rewards, flags)
|
|
||||||
|
|
||||||
let
|
let
|
||||||
proposer_index = get_beacon_proposer_index(
|
proposer_index = get_beacon_proposer_index(
|
||||||
@ -107,7 +106,7 @@ proc addTestBlock*(
|
|||||||
case state.beaconStateFork
|
case state.beaconStateFork
|
||||||
of forkPhase0:
|
of forkPhase0:
|
||||||
let res = makeBeaconBlock(
|
let res = makeBeaconBlock(
|
||||||
defaultRuntimeConfig,
|
cfg,
|
||||||
state.hbsPhase0,
|
state.hbsPhase0,
|
||||||
proposer_index.get(),
|
proposer_index.get(),
|
||||||
parent_root,
|
parent_root,
|
||||||
@ -130,7 +129,7 @@ proc addTestBlock*(
|
|||||||
ForkedBeaconBlock.init(res.get())
|
ForkedBeaconBlock.init(res.get())
|
||||||
of forkAltair:
|
of forkAltair:
|
||||||
let res = makeBeaconBlock(
|
let res = makeBeaconBlock(
|
||||||
defaultRuntimeConfig,
|
cfg,
|
||||||
state.hbsAltair,
|
state.hbsAltair,
|
||||||
proposer_index.get(),
|
proposer_index.get(),
|
||||||
parent_root,
|
parent_root,
|
||||||
@ -169,7 +168,8 @@ proc makeTestBlock*(
|
|||||||
eth1_data = Eth1Data(),
|
eth1_data = Eth1Data(),
|
||||||
attestations = newSeq[Attestation](),
|
attestations = newSeq[Attestation](),
|
||||||
deposits = newSeq[Deposit](),
|
deposits = newSeq[Deposit](),
|
||||||
graffiti = default(GraffitiBytes)): ForkedSignedBeaconBlock =
|
graffiti = default(GraffitiBytes),
|
||||||
|
cfg = defaultRuntimeConfig): ForkedSignedBeaconBlock =
|
||||||
# Create a block for `state.slot + 1` - like a block proposer would do!
|
# Create a block for `state.slot + 1` - like a block proposer would do!
|
||||||
# It's a bit awkward - in order to produce a block for N+1, we need to
|
# It's a bit awkward - in order to produce a block for N+1, we need to
|
||||||
# calculate what the state will look like after that block has been applied,
|
# calculate what the state will look like after that block has been applied,
|
||||||
@ -177,7 +177,7 @@ proc makeTestBlock*(
|
|||||||
var tmpState = assignClone(state)
|
var tmpState = assignClone(state)
|
||||||
addTestBlock(
|
addTestBlock(
|
||||||
tmpState[], parent_root, cache, eth1_data, attestations, deposits,
|
tmpState[], parent_root, cache, eth1_data, attestations, deposits,
|
||||||
graffiti)
|
graffiti, cfg = cfg)
|
||||||
|
|
||||||
func makeAttestationData*(
|
func makeAttestationData*(
|
||||||
state: ForkedHashedBeaconState, slot: Slot, committee_index: CommitteeIndex,
|
state: ForkedHashedBeaconState, slot: Slot, committee_index: CommitteeIndex,
|
||||||
@ -315,7 +315,8 @@ iterator makeTestBlocks*(
|
|||||||
parent_root: Eth2Digest,
|
parent_root: Eth2Digest,
|
||||||
cache: var StateCache,
|
cache: var StateCache,
|
||||||
blocks: int,
|
blocks: int,
|
||||||
attested: bool): ForkedSignedBeaconBlock =
|
attested: bool,
|
||||||
|
cfg = defaultRuntimeConfig): ForkedSignedBeaconBlock =
|
||||||
var
|
var
|
||||||
state = assignClone(state)[]
|
state = assignClone(state)[]
|
||||||
parent_root = parent_root
|
parent_root = parent_root
|
||||||
@ -326,7 +327,7 @@ iterator makeTestBlocks*(
|
|||||||
@[]
|
@[]
|
||||||
|
|
||||||
let blck = addTestBlock(
|
let blck = addTestBlock(
|
||||||
state, parent_root, cache, attestations = attestations)
|
state, parent_root, cache, attestations = attestations, cfg = cfg)
|
||||||
yield blck
|
yield blck
|
||||||
parent_root = blck.root
|
parent_root = blck.root
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user