2019-02-19 17:35:02 -06:00
|
|
|
# beacon_chain
|
|
|
|
# Copyright (c) 2018 Status Research & Development GmbH
|
|
|
|
# Licensed and distributed under either of
|
2019-11-25 15:30:02 +00:00
|
|
|
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
|
|
|
|
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
|
2019-02-19 17:35:02 -06:00
|
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
|
2019-11-14 10:47:55 +00:00
|
|
|
{.used.}
|
|
|
|
|
2019-02-19 17:35:02 -06:00
|
|
|
import
|
2019-11-14 10:47:55 +00:00
|
|
|
options, unittest,
|
2019-11-26 02:01:16 +02:00
|
|
|
chronicles,
|
2019-12-03 17:45:12 +01:00
|
|
|
./testutil, ./testblockutil,
|
2019-02-19 17:35:02 -06:00
|
|
|
../beacon_chain/spec/[beaconstate, crypto, datatypes, digest, helpers, validator],
|
2019-03-12 16:03:14 +01:00
|
|
|
../beacon_chain/[beacon_node_types, attestation_pool, block_pool, extras, state_transition, ssz]
|
2019-02-19 17:35:02 -06:00
|
|
|
|
2019-06-03 10:26:38 +02:00
|
|
|
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..
|
2019-07-15 23:10:40 +02:00
|
|
|
process_slots(state.data, state.data.data.slot + 1)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
|
|
|
body
|
|
|
|
|
2019-05-27 14:48:13 +02:00
|
|
|
suite "Attestation pool processing" & preset():
|
2019-02-19 17:35:02 -06:00
|
|
|
## For now just test that we can compile and execute block processing with
|
|
|
|
## mock data.
|
|
|
|
|
2019-06-03 10:26:38 +02:00
|
|
|
# Genesis state that results in 2 members per committee
|
2019-03-13 16:59:20 -06:00
|
|
|
let
|
2019-07-10 12:23:02 +00:00
|
|
|
genState = initialize_beacon_state_from_eth1(
|
2019-09-02 12:31:14 +02:00
|
|
|
Eth2Digest(), 0,
|
|
|
|
makeInitialDeposits(SLOTS_PER_EPOCH * 2, {skipValidation}),
|
|
|
|
{skipValidation})
|
2019-02-28 15:21:29 -06:00
|
|
|
genBlock = get_initial_beacon_block(genState)
|
|
|
|
|
2019-12-05 10:27:00 +00:00
|
|
|
timedTest "Can add and retrieve simple attestation" & preset():
|
2019-06-24 09:21:56 +00:00
|
|
|
var cache = get_empty_per_epoch_cache()
|
2019-06-03 10:26:38 +02:00
|
|
|
withPool:
|
|
|
|
let
|
|
|
|
# Create an attestation for slot 1!
|
2019-11-11 12:43:00 +01:00
|
|
|
beacon_committee = get_beacon_committee(state.data.data,
|
|
|
|
state.data.data.slot, 0, cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
attestation = makeAttestation(
|
2019-11-15 23:37:39 +01:00
|
|
|
state.data.data, state.blck.root, beacon_committee[0], cache)
|
2019-02-19 17:35:02 -06:00
|
|
|
|
2019-08-19 18:41:13 +02:00
|
|
|
pool.add(state.data.data, state.blck, attestation)
|
2019-02-19 17:35:02 -06:00
|
|
|
|
2019-07-15 23:10:40 +02:00
|
|
|
process_slots(state.data, MIN_ATTESTATION_INCLUSION_DELAY.Slot) # minus 1?
|
2019-02-19 17:35:02 -06:00
|
|
|
|
2019-06-03 10:26:38 +02:00
|
|
|
let attestations = pool.getAttestationsForBlock(
|
|
|
|
state.data.data, state.data.data.slot + 1)
|
2019-02-19 17:35:02 -06:00
|
|
|
|
2019-06-03 10:26:38 +02:00
|
|
|
check:
|
|
|
|
attestations.len == 1
|
2019-02-20 22:42:17 -06:00
|
|
|
|
2019-12-05 10:27:00 +00:00
|
|
|
timedTest "Attestations may arrive in any order" & preset():
|
2019-06-24 09:21:56 +00:00
|
|
|
var cache = get_empty_per_epoch_cache()
|
2019-06-03 10:26:38 +02:00
|
|
|
withPool:
|
|
|
|
let
|
|
|
|
# Create an attestation for slot 1!
|
2019-11-11 12:43:00 +01:00
|
|
|
bc0 = get_beacon_committee(state.data.data,
|
|
|
|
state.data.data.slot, 0, cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
attestation0 = makeAttestation(
|
2019-11-15 23:37:39 +01:00
|
|
|
state.data.data, state.blck.root, bc0[0], cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
2019-07-15 23:10:40 +02:00
|
|
|
process_slots(state.data, state.data.data.slot + 1)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
|
|
|
let
|
2019-11-12 06:35:52 +01:00
|
|
|
bc1 = get_beacon_committee(state.data.data,
|
|
|
|
state.data.data.slot, 0, cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
attestation1 = makeAttestation(
|
2019-11-15 23:37:39 +01:00
|
|
|
state.data.data, state.blck.root, bc1[0], cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
|
|
|
# test reverse order
|
2019-08-19 18:41:13 +02:00
|
|
|
pool.add(state.data.data, state.blck, attestation1)
|
|
|
|
pool.add(state.data.data, state.blck, attestation0)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
2019-07-15 23:10:40 +02:00
|
|
|
process_slots(state.data, MIN_ATTESTATION_INCLUSION_DELAY.Slot) # minus 1?
|
2019-06-03 10:26:38 +02:00
|
|
|
|
|
|
|
let attestations = pool.getAttestationsForBlock(
|
|
|
|
state.data.data, state.data.data.slot + 1)
|
|
|
|
|
|
|
|
check:
|
|
|
|
attestations.len == 1
|
|
|
|
|
2019-12-05 10:27:00 +00:00
|
|
|
timedTest "Attestations should be combined" & preset():
|
2019-06-24 09:21:56 +00:00
|
|
|
var cache = get_empty_per_epoch_cache()
|
2019-06-03 10:26:38 +02:00
|
|
|
withPool:
|
|
|
|
let
|
|
|
|
# Create an attestation for slot 1!
|
2019-11-11 12:43:00 +01:00
|
|
|
bc0 = get_beacon_committee(state.data.data,
|
|
|
|
state.data.data.slot, 0, cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
attestation0 = makeAttestation(
|
2019-11-15 23:37:39 +01:00
|
|
|
state.data.data, state.blck.root, bc0[0], cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
attestation1 = makeAttestation(
|
2019-11-15 23:37:39 +01:00
|
|
|
state.data.data, state.blck.root, bc0[1], cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
2019-08-19 18:41:13 +02:00
|
|
|
pool.add(state.data.data, state.blck, attestation0)
|
|
|
|
pool.add(state.data.data, state.blck, attestation1)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
2019-07-15 23:10:40 +02:00
|
|
|
process_slots(state.data, MIN_ATTESTATION_INCLUSION_DELAY.Slot) # minus 1?
|
2019-06-03 10:26:38 +02:00
|
|
|
|
|
|
|
let attestations = pool.getAttestationsForBlock(
|
|
|
|
state.data.data, state.data.data.slot + 1)
|
|
|
|
|
|
|
|
check:
|
|
|
|
attestations.len == 1
|
|
|
|
|
2019-12-05 10:27:00 +00:00
|
|
|
timedTest "Attestations may overlap, bigger first" & preset():
|
2019-06-24 09:21:56 +00:00
|
|
|
var cache = get_empty_per_epoch_cache()
|
2019-06-03 10:26:38 +02:00
|
|
|
withPool:
|
|
|
|
|
|
|
|
var
|
|
|
|
# Create an attestation for slot 1!
|
2019-11-11 12:43:00 +01:00
|
|
|
bc0 = get_beacon_committee(state.data.data,
|
|
|
|
state.data.data.slot, 0, cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
attestation0 = makeAttestation(
|
2019-11-15 23:37:39 +01:00
|
|
|
state.data.data, state.blck.root, bc0[0], cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
attestation1 = makeAttestation(
|
2019-11-15 23:37:39 +01:00
|
|
|
state.data.data, state.blck.root, bc0[1], cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
|
|
|
attestation0.combine(attestation1, {skipValidation})
|
|
|
|
|
2019-08-19 18:41:13 +02:00
|
|
|
pool.add(state.data.data, state.blck, attestation0)
|
|
|
|
pool.add(state.data.data, state.blck, attestation1)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
2019-07-15 23:10:40 +02:00
|
|
|
process_slots(state.data, MIN_ATTESTATION_INCLUSION_DELAY.Slot) # minus 1?
|
2019-06-03 10:26:38 +02:00
|
|
|
|
|
|
|
let attestations = pool.getAttestationsForBlock(
|
|
|
|
state.data.data, state.data.data.slot + 1)
|
|
|
|
|
|
|
|
check:
|
|
|
|
attestations.len == 1
|
|
|
|
|
2019-12-05 10:27:00 +00:00
|
|
|
timedTest "Attestations may overlap, smaller first" & preset():
|
2019-06-24 09:21:56 +00:00
|
|
|
var cache = get_empty_per_epoch_cache()
|
2019-06-03 10:26:38 +02:00
|
|
|
withPool:
|
|
|
|
var
|
|
|
|
# Create an attestation for slot 1!
|
2019-11-11 12:43:00 +01:00
|
|
|
bc0 = get_beacon_committee(state.data.data,
|
|
|
|
state.data.data.slot, 0, cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
attestation0 = makeAttestation(
|
2019-11-15 23:37:39 +01:00
|
|
|
state.data.data, state.blck.root, bc0[0], cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
attestation1 = makeAttestation(
|
2019-11-15 23:37:39 +01:00
|
|
|
state.data.data, state.blck.root, bc0[1], cache)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
|
|
|
attestation0.combine(attestation1, {skipValidation})
|
|
|
|
|
2019-08-19 18:41:13 +02:00
|
|
|
pool.add(state.data.data, state.blck, attestation1)
|
|
|
|
pool.add(state.data.data, state.blck, attestation0)
|
2019-06-03 10:26:38 +02:00
|
|
|
|
2019-07-15 23:10:40 +02:00
|
|
|
process_slots(state.data, MIN_ATTESTATION_INCLUSION_DELAY.Slot) # minus 1?
|
2019-06-03 10:26:38 +02:00
|
|
|
|
|
|
|
let attestations = pool.getAttestationsForBlock(
|
|
|
|
state.data.data, state.data.data.slot + 1)
|
|
|
|
|
|
|
|
check:
|
|
|
|
attestations.len == 1
|