// Copyright 2015-2019 Parity Technologies (UK) Ltd. // This file is part of Parity Ethereum. // Parity Ethereum is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // Parity Ethereum is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License // along with Parity Ethereum. If not, see . //! Additional test structures deserialization. use std::collections::BTreeMap; use std::io::Read; use serde_json; use serde_json::Error; use hash::H256; use uint::Uint; /// Blockchain test header deserializer. #[derive(Debug, PartialEq, Deserialize)] #[serde(rename_all = "camelCase")] pub struct DifficultyTestCase { /// Parent timestamp. pub parent_timestamp: Uint, /// Parent difficulty. pub parent_difficulty: Uint, /// Parent uncle hash. pub parent_uncles: H256, /// Current timestamp. pub current_timestamp: Uint, /// Current difficulty. pub current_difficulty: Uint, /// Current block number. pub current_block_number: Uint, } /// Blockchain test deserializer. #[derive(Debug, PartialEq, Deserialize)] pub struct DifficultyTest(BTreeMap); impl IntoIterator for DifficultyTest { type Item = as IntoIterator>::Item; type IntoIter = as IntoIterator>::IntoIter; fn into_iter(self) -> Self::IntoIter { self.0.into_iter() } } impl DifficultyTest { /// Loads test from json. pub fn load(reader: R) -> Result where R: Read { serde_json::from_reader(reader) } } /// Test to skip (only if issue ongoing) #[derive(Debug, PartialEq, Deserialize)] pub struct SkipStates { /// Block tests pub block: Vec, /// State tests pub state: Vec, } /// Block test to skip. #[derive(Debug, PartialEq, Deserialize)] pub struct BlockSkipStates { /// Issue reference. pub reference: String, /// Test failing name. pub failing: String, /// Items failing for the test. pub subtests: Vec, } /// State test to skip. #[derive(Debug, PartialEq, Deserialize)] pub struct StateSkipStates { /// Issue reference. pub reference: String, /// Test failing name. pub failing: String, /// Items failing for the test. pub subtests: BTreeMap } /// State subtest to skip. #[derive(Debug, PartialEq, Deserialize)] pub struct StateSkipSubStates { /// State test number of this item. Or '*' for all state. pub subnumbers: Vec, /// Chain for this items. pub chain: String, } impl SkipStates { /// Loads skip states from json. pub fn load(reader: R) -> Result where R: Read { serde_json::from_reader(reader) } /// Empty skip states. pub fn empty() -> Self { SkipStates { block: Vec::new(), state: Vec::new(), } } }