2018-12-17 12:03:53 -06:00
|
|
|
import
|
2019-01-23 20:45:15 +02:00
|
|
|
confutils,
|
2018-12-27 17:40:22 -06:00
|
|
|
../beacon_chain/[extras, ssz],
|
2019-01-26 11:52:30 -08:00
|
|
|
../beacon_chain/spec/[beaconstate, datatypes, digest, validator],
|
2019-01-23 20:45:15 +02:00
|
|
|
../tests/testutil
|
2018-12-17 12:03:53 -06:00
|
|
|
|
2018-12-27 14:14:37 -06:00
|
|
|
proc stateSize(deposits: int, maxContent = false) =
|
|
|
|
var state = get_initial_beacon_state(
|
2019-01-17 17:42:17 -08:00
|
|
|
makeInitialDeposits(deposits), 0, Eth1Data(), {skipValidation})
|
2018-12-17 12:03:53 -06:00
|
|
|
|
2018-12-27 14:14:37 -06:00
|
|
|
if maxContent:
|
|
|
|
# TODO verify this is correct, but generally we collect up to two epochs
|
|
|
|
# of attestations, and each block has a cap on the number of
|
|
|
|
# attestations it may hold, so we'll just add so many of them
|
|
|
|
state.latest_attestations.setLen(MAX_ATTESTATIONS * EPOCH_LENGTH * 2)
|
2019-01-26 11:52:30 -08:00
|
|
|
let
|
|
|
|
crosslink_committees = get_crosslink_committees_at_slot(state, 0)
|
|
|
|
validatorsPerCommittee =
|
2019-02-06 20:37:25 +01:00
|
|
|
len(crosslink_committees[0].committee) # close enough..
|
2018-12-27 14:14:37 -06:00
|
|
|
for a in state.latest_attestations.mitems():
|
2019-02-07 16:55:48 +00:00
|
|
|
a.aggregation_bitfield.setLen(validatorsPerCommittee)
|
2018-12-17 12:03:53 -06:00
|
|
|
echo "Validators: ", deposits, ", total: ", state.serialize().len
|
|
|
|
|
2018-12-27 14:14:37 -06:00
|
|
|
dispatch(stateSize)
|