use super::*; use crate::case_result::compare_beacon_state_results_without_caches; use serde_derive::Deserialize; use state_processing::per_epoch_processing::registry_updates::process_registry_updates; use types::{BeaconState, EthSpec}; #[derive(Debug, Clone, Deserialize)] pub struct EpochProcessingRegistryUpdates { pub description: String, #[serde(bound = "E: EthSpec")] pub pre: BeaconState, #[serde(bound = "E: EthSpec")] pub post: Option>, } impl YamlDecode for EpochProcessingRegistryUpdates { fn yaml_decode(yaml: &str) -> Result { Ok(serde_yaml::from_str(yaml).unwrap()) } } impl Case for EpochProcessingRegistryUpdates { fn description(&self) -> String { self.description.clone() } fn result(&self, _case_index: usize) -> Result<(), Error> { let mut state = self.pre.clone(); let mut expected = self.post.clone(); let spec = &E::default_spec(); // Processing requires the epoch cache. state.build_all_caches(spec).unwrap(); let mut result = process_registry_updates(&mut state, spec).map(|_| state); compare_beacon_state_results_without_caches(&mut result, &mut expected) } }