process_block_header tests

This commit is contained in:
Darren Langley 2019-04-10 21:56:31 +10:00
parent 8366352aaa
commit f9c1800c00

View File

@ -1,6 +1,7 @@
#![cfg(test)] #![cfg(test)]
use crate::per_block_processing; use crate::per_block_processing;
use super::block_processing_builder::BlockProcessingBuilder; use super::block_processing_builder::BlockProcessingBuilder;
use super::errors::*;
use types::*; use types::*;
pub const VALIDATOR_COUNT: usize = 10; pub const VALIDATOR_COUNT: usize = 10;
@ -8,23 +9,43 @@ pub const VALIDATOR_COUNT: usize = 10;
#[test] #[test]
fn runs_without_error() { fn runs_without_error() {
let spec = ChainSpec::foundation(); let spec = ChainSpec::foundation();
let (block, mut state) = get_block_state(&spec);
per_block_processing(&mut state, &block, &spec).unwrap();
}
#[test]
fn process_block_header_invalid_state_slot() {
let spec = ChainSpec::foundation();
let (mut block, mut state) = get_block_state(&spec);
state.slot = Slot::new(133713);
block.slot = Slot::new(424242);
let result = per_block_processing(&mut state, &block, &spec);
assert_eq!(result, Err(BlockProcessingError::Invalid(BlockInvalid::StateSlotMismatch)));
}
#[test]
#[ignore]
fn process_block_header_invalid_parent_block_root() {
// this will be changed in spec 0.5.1 to use signed root
}
fn get_block_state(spec: &ChainSpec) -> (BeaconBlock, BeaconState) {
let mut builder = BlockProcessingBuilder::new(VALIDATOR_COUNT, &spec); let mut builder = BlockProcessingBuilder::new(VALIDATOR_COUNT, &spec);
// Set the state and block to be in the last slot of the 4th epoch. // Set the state and block to be in the last slot of the 4th epoch.
let last_slot_of_epoch = (spec.genesis_epoch + 4).end_slot(spec.slots_per_epoch); let last_slot_of_epoch = (spec.genesis_epoch + 4).end_slot(spec.slots_per_epoch);
builder.set_slot(last_slot_of_epoch, &spec); builder.set_slot(last_slot_of_epoch, &spec);
builder.build_caches(&spec); builder.build_caches(&spec);
let (block, mut state) = builder.build(&spec); let (block, state) = builder.build(&spec);
per_block_processing(&mut state, &block, &spec).unwrap(); (block, state)
} }
// process_block_header
// Invalid::StateSlotMismatch
// Invalid::ParentBlockRootMismatch
// verify_block_signature // verify_block_signature
// Invalid::BadSignature // Invalid::BadSignature