nimbus-eth2/tests/test_attestation_pool.nim
Dustin Brody 63e621c27d
initial 0.9.0 spec sync (#509)
* rename compute_epoch_of_slot(...) to compute_epoch_at_slot(...)

* remove some unnecessary imports; remove some crosslink-related code and tests; complete renaming of compute_epoch_of_slot(...) to compute_epoch_at_slot(...)

* rm more transfer-related code and tests; rm more unnecessary strutils imports

* rm remaining unused imports

* remove useless get_empty_per_epoch_cache(...)/compute_start_slot_of_epoch(...) calls

* rename compute_start_slot_of_epoch(...) to compute_start_slot_at_epoch(...)

* rename ACTIVATION_EXIT_DELAY to MAX_SEED_LOOKAHEAD

* update domain types to 0.9.0

* mark AttesterSlashing, IndexedAttestation, AttestationDataAndCustodyBit, DepositData, BeaconBlockHeader, Fork, integer_squareroot(...), and process_voluntary_exit(...) as 0.9.0

* mark increase_balance(...), decrease_balance(...), get_block_root(...), CheckPoint, Deposit, PendingAttestation, HistoricalBatch, is_active_validator(...), and is_slashable_attestation_data(...) as 0.9.0

* mark compute_activation_exit_epoch(...), bls_verify(...), Validator, get_active_validator_indices(...), get_current_epoch(...), get_total_active_balance(...), and get_previous_epoch(...) as 0.9.0

* mark get_block_root_at_slot(...), ProposerSlashing, get_domain(...), VoluntaryExit, mainnet preset Gwei values, minimal preset max operations, process_block_header(...), and is_slashable_validator(...) as 0.9.0

* mark makeWithdrawalCredentials(...), get_validator_churn_limit(...), get_total_balance(...), is_valid_indexed_attestation(...), bls_aggregate_pubkeys(...), initial genesis value/constants, Attestation, get_randao_mix(...), mainnet preset max operations per block constants, minimal preset Gwei values and time parameters, process_eth1_data(...), get_shuffled_seq(...), compute_committee(...), and process_slots(...) as 0.9.0; partially update get_indexed_attestation(...) to 0.9.0 by removing crosslink refs and associated tests

* mark initiate_validator_exit(...), process_registry_updates(...), BeaconBlock, Eth1Data, compute_domain(...), process_randao(...), process_attester_slashing(...), get_base_reward(...), and process_slot(...) as 0.9.0
2019-10-30 19:41:19 +00:00

161 lines
5.7 KiB
Nim

# beacon_chain
# Copyright (c) 2018 Status Research & Development GmbH
# Licensed and distributed under either of
# * MIT license (license terms in the root directory or at http://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at http://www.apache.org/licenses/LICENSE-2.0).
# at your option. This file may not be copied, modified, or distributed except according to those terms.
import
options, sequtils, unittest,
./testutil,
../beacon_chain/spec/[beaconstate, crypto, datatypes, digest, helpers, validator],
../beacon_chain/[beacon_node_types, attestation_pool, block_pool, extras, state_transition, ssz]
template withPool(body: untyped) =
mixin genState, genBlock
var
blockPool {.inject.} = BlockPool.init(makeTestDB(genState, genBlock))
pool {.inject.} = AttestationPool.init(blockPool)
state {.inject.} = loadTailState(blockPool)
# Slot 0 is a finalized slot - won't be making attestations for it..
process_slots(state.data, state.data.data.slot + 1)
body
suite "Attestation pool processing" & preset():
## For now just test that we can compile and execute block processing with
## mock data.
# Genesis state that results in 2 members per committee
let
genState = initialize_beacon_state_from_eth1(
Eth2Digest(), 0,
makeInitialDeposits(SLOTS_PER_EPOCH * 2, {skipValidation}),
{skipValidation})
genBlock = get_initial_beacon_block(genState)
test "Can add and retrieve simple attestation" & preset():
var cache = get_empty_per_epoch_cache()
withPool:
let
# Create an attestation for slot 1!
crosslink_committee = get_crosslink_committee(state.data.data,
compute_epoch_at_slot(state.data.data.slot), 1, cache)
attestation = makeAttestation(
state.data.data, state.blck.root, crosslink_committee[0])
pool.add(state.data.data, state.blck, attestation)
process_slots(state.data, MIN_ATTESTATION_INCLUSION_DELAY.Slot) # minus 1?
let attestations = pool.getAttestationsForBlock(
state.data.data, state.data.data.slot + 1)
check:
attestations.len == 1
test "Attestations may arrive in any order" & preset():
var cache = get_empty_per_epoch_cache()
withPool:
let
# Create an attestation for slot 1!
cc0 = get_crosslink_committee(state.data.data,
compute_epoch_at_slot(state.data.data.slot), 1, cache)
attestation0 = makeAttestation(
state.data.data, state.blck.root, cc0[0])
process_slots(state.data, state.data.data.slot + 1)
let
cc1 = get_crosslink_committee(state.data.data,
compute_epoch_at_slot(state.data.data.slot), 2, cache)
attestation1 = makeAttestation(
state.data.data, state.blck.root, cc1[0])
# test reverse order
pool.add(state.data.data, state.blck, attestation1)
pool.add(state.data.data, state.blck, attestation0)
process_slots(state.data, MIN_ATTESTATION_INCLUSION_DELAY.Slot) # minus 1?
let attestations = pool.getAttestationsForBlock(
state.data.data, state.data.data.slot + 1)
check:
attestations.len == 1
test "Attestations should be combined" & preset():
var cache = get_empty_per_epoch_cache()
withPool:
let
# Create an attestation for slot 1!
cc0 = get_crosslink_committee(state.data.data,
compute_epoch_at_slot(state.data.data.slot), 1, cache)
attestation0 = makeAttestation(
state.data.data, state.blck.root, cc0[0])
attestation1 = makeAttestation(
state.data.data, state.blck.root, cc0[1])
pool.add(state.data.data, state.blck, attestation0)
pool.add(state.data.data, state.blck, attestation1)
process_slots(state.data, MIN_ATTESTATION_INCLUSION_DELAY.Slot) # minus 1?
let attestations = pool.getAttestationsForBlock(
state.data.data, state.data.data.slot + 1)
check:
attestations.len == 1
test "Attestations may overlap, bigger first" & preset():
var cache = get_empty_per_epoch_cache()
withPool:
var
# Create an attestation for slot 1!
cc0 = get_crosslink_committee(state.data.data,
compute_epoch_at_slot(state.data.data.slot), 1, cache)
attestation0 = makeAttestation(
state.data.data, state.blck.root, cc0[0])
attestation1 = makeAttestation(
state.data.data, state.blck.root, cc0[1])
attestation0.combine(attestation1, {skipValidation})
pool.add(state.data.data, state.blck, attestation0)
pool.add(state.data.data, state.blck, attestation1)
process_slots(state.data, MIN_ATTESTATION_INCLUSION_DELAY.Slot) # minus 1?
let attestations = pool.getAttestationsForBlock(
state.data.data, state.data.data.slot + 1)
check:
attestations.len == 1
test "Attestations may overlap, smaller first" & preset():
var cache = get_empty_per_epoch_cache()
withPool:
var
# Create an attestation for slot 1!
cc0 = get_crosslink_committee(state.data.data,
compute_epoch_at_slot(state.data.data.slot), 1, cache)
attestation0 = makeAttestation(
state.data.data, state.blck.root, cc0[0])
attestation1 = makeAttestation(
state.data.data, state.blck.root, cc0[1])
attestation0.combine(attestation1, {skipValidation})
pool.add(state.data.data, state.blck, attestation1)
pool.add(state.data.data, state.blck, attestation0)
process_slots(state.data, MIN_ATTESTATION_INCLUSION_DELAY.Slot) # minus 1?
let attestations = pool.getAttestationsForBlock(
state.data.data, state.data.data.slot + 1)
check:
attestations.len == 1