2019-05-15 18:36:32 +02:00
|
|
|
from eth2spec.test.helpers.keys import pubkeys
|
2019-06-01 01:51:09 +02:00
|
|
|
from eth2spec.utils.ssz.ssz_impl import hash_tree_root
|
2019-06-22 19:48:06 +02:00
|
|
|
from eth2spec.utils.ssz.ssz_typing import List
|
2019-05-15 18:36:32 +02:00
|
|
|
|
|
|
|
|
2019-05-30 22:57:18 +02:00
|
|
|
def build_mock_validator(spec, i: int, balance: int):
|
2019-05-15 18:36:32 +02:00
|
|
|
pubkey = pubkeys[i]
|
|
|
|
# insecurely use pubkey as withdrawal key as well
|
2019-07-01 00:36:24 +02:00
|
|
|
withdrawal_credentials = spec.BLS_WITHDRAWAL_PREFIX + spec.hash(pubkey)[1:]
|
2019-05-15 18:36:32 +02:00
|
|
|
return spec.Validator(
|
|
|
|
pubkey=pubkeys[i],
|
|
|
|
withdrawal_credentials=withdrawal_credentials,
|
|
|
|
activation_eligibility_epoch=spec.FAR_FUTURE_EPOCH,
|
|
|
|
activation_epoch=spec.FAR_FUTURE_EPOCH,
|
|
|
|
exit_epoch=spec.FAR_FUTURE_EPOCH,
|
|
|
|
withdrawable_epoch=spec.FAR_FUTURE_EPOCH,
|
|
|
|
effective_balance=min(balance - balance % spec.EFFECTIVE_BALANCE_INCREMENT, spec.MAX_EFFECTIVE_BALANCE)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2019-05-30 22:57:18 +02:00
|
|
|
def create_genesis_state(spec, num_validators):
|
2019-05-15 18:36:32 +02:00
|
|
|
deposit_root = b'\x42' * 32
|
|
|
|
|
|
|
|
state = spec.BeaconState(
|
|
|
|
genesis_time=0,
|
2019-06-09 20:41:21 +01:00
|
|
|
eth1_deposit_index=num_validators,
|
|
|
|
eth1_data=spec.Eth1Data(
|
2019-05-15 18:36:32 +02:00
|
|
|
deposit_root=deposit_root,
|
|
|
|
deposit_count=num_validators,
|
2019-06-30 16:10:22 +01:00
|
|
|
block_hash=spec.Hash(),
|
2019-06-25 10:31:39 -06:00
|
|
|
),
|
|
|
|
latest_block_header=spec.BeaconBlockHeader(body_root=spec.hash_tree_root(spec.BeaconBlockBody())),
|
|
|
|
)
|
2019-05-15 18:36:32 +02:00
|
|
|
|
|
|
|
# We "hack" in the initial validators,
|
|
|
|
# as it is much faster than creating and processing genesis deposits for every single test case.
|
|
|
|
state.balances = [spec.MAX_EFFECTIVE_BALANCE] * num_validators
|
2019-06-09 20:41:21 +01:00
|
|
|
state.validators = [build_mock_validator(spec, i, state.balances[i]) for i in range(num_validators)]
|
2019-05-15 18:36:32 +02:00
|
|
|
|
|
|
|
# Process genesis activations
|
2019-06-09 20:41:21 +01:00
|
|
|
for validator in state.validators:
|
2019-05-15 18:36:32 +02:00
|
|
|
if validator.effective_balance >= spec.MAX_EFFECTIVE_BALANCE:
|
|
|
|
validator.activation_eligibility_epoch = spec.GENESIS_EPOCH
|
|
|
|
validator.activation_epoch = spec.GENESIS_EPOCH
|
|
|
|
|
|
|
|
return state
|