Merge branch 'json_tests_refactor' into eth_call
This commit is contained in:
		
						commit
						9a227dce46
					
				| @ -16,18 +16,19 @@ | |||||||
| 
 | 
 | ||||||
| use super::test_common::*; | use super::test_common::*; | ||||||
| use client::{BlockChainClient, Client, ClientConfig}; | use client::{BlockChainClient, Client, ClientConfig}; | ||||||
| use pod_state::*; |  | ||||||
| use block::Block; | use block::Block; | ||||||
| use ethereum; | use ethereum; | ||||||
| use tests::helpers::*; | use tests::helpers::*; | ||||||
| use devtools::*; | use devtools::*; | ||||||
|  | use spec::Genesis; | ||||||
|  | use ethjson; | ||||||
| 
 | 
 | ||||||
| pub fn json_chain_test(json_data: &[u8], era: ChainEra) -> Vec<String> { | pub fn json_chain_test(json_data: &[u8], era: ChainEra) -> Vec<String> { | ||||||
| 	init_log(); | 	init_log(); | ||||||
| 	let json = Json::from_str(::std::str::from_utf8(json_data).unwrap()).expect("Json is invalid"); | 	let tests = ethjson::blockchain::Test::load(json_data).unwrap(); | ||||||
| 	let mut failed = Vec::new(); | 	let mut failed = Vec::new(); | ||||||
| 
 | 
 | ||||||
| 	for (name, test) in json.as_object().unwrap() { | 	for (name, blockchain) in tests.deref() { | ||||||
| 		let mut fail = false; | 		let mut fail = false; | ||||||
| 		{ | 		{ | ||||||
| 			let mut fail_unless = |cond: bool| if !cond && !fail { | 			let mut fail_unless = |cond: bool| if !cond && !fail { | ||||||
| @ -39,37 +40,36 @@ pub fn json_chain_test(json_data: &[u8], era: ChainEra) -> Vec<String> { | |||||||
| 
 | 
 | ||||||
| 			flush!("   - {}...", name); | 			flush!("   - {}...", name); | ||||||
| 
 | 
 | ||||||
| 			let blocks: Vec<(Bytes, bool)> = test["blocks"].as_array().unwrap().iter().map(|e| (xjson!(&e["rlp"]), e.find("blockHeader").is_some())).collect(); |  | ||||||
| 			let mut spec = match era { | 			let mut spec = match era { | ||||||
| 				ChainEra::Frontier => ethereum::new_frontier_test(), | 				ChainEra::Frontier => ethereum::new_frontier_test(), | ||||||
| 				ChainEra::Homestead => ethereum::new_homestead_test(), | 				ChainEra::Homestead => ethereum::new_homestead_test(), | ||||||
| 			}; | 			}; | ||||||
| 			let s = PodState::from_json(test.find("pre").unwrap()); | 
 | ||||||
| 			spec.set_genesis_state(s); | 			let genesis = Genesis::from(blockchain.genesis()); | ||||||
| 			spec.overwrite_genesis(test.find("genesisBlockHeader").unwrap()); | 			let state = From::from(blockchain.pre_state.clone()); | ||||||
|  | 			spec.set_genesis_state(state); | ||||||
|  | 			spec.overwrite_genesis_params(genesis); | ||||||
| 			assert!(spec.is_state_root_valid()); | 			assert!(spec.is_state_root_valid()); | ||||||
| 			let genesis_hash = spec.genesis_header().hash(); |  | ||||||
| 			assert_eq!(genesis_hash, H256::from_json(&test.find("genesisBlockHeader").unwrap()["hash"])); |  | ||||||
| 
 | 
 | ||||||
| 			let temp = RandomTempPath::new(); | 			let temp = RandomTempPath::new(); | ||||||
| 			{ | 			{ | ||||||
| 				let client = Client::new(ClientConfig::default(), spec, temp.as_path(), IoChannel::disconnected()).unwrap(); | 				let client = Client::new(ClientConfig::default(), spec, temp.as_path(), IoChannel::disconnected()).unwrap(); | ||||||
| 				assert_eq!(client.chain_info().best_block_hash, genesis_hash); | 				for b in &blockchain.blocks_rlp() { | ||||||
| 				for (b, is_valid) in blocks.into_iter() { |  | ||||||
| 					if Block::is_good(&b) { | 					if Block::is_good(&b) { | ||||||
| 						let _ = client.import_block(b.clone()); | 						let _ = client.import_block(b.clone()); | ||||||
| 					} |  | ||||||
| 						client.flush_queue(); | 						client.flush_queue(); | ||||||
| 					let imported_ok = client.import_verified_blocks(&IoChannel::disconnected()) > 0; | 						client.import_verified_blocks(&IoChannel::disconnected()); | ||||||
| 					assert_eq!(imported_ok, is_valid); |  | ||||||
| 				} |  | ||||||
| 				fail_unless(client.chain_info().best_block_hash == H256::from_json(&test["lastblockhash"])); |  | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
|  | 				fail_unless(client.chain_info().best_block_hash == blockchain.best_block.clone().into()); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		if !fail { | 		if !fail { | ||||||
| 			flushln!("ok"); | 			flushln!("ok"); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	println!("!!! {:?} tests from failed.", failed.len()); | 	println!("!!! {:?} tests from failed.", failed.len()); | ||||||
| 	failed | 	failed | ||||||
| } | } | ||||||
|  | |||||||
| @ -82,7 +82,8 @@ impl From<ethjson::blockchain::Account> for PodAccount { | |||||||
| 			code: a.code.into(), | 			code: a.code.into(), | ||||||
| 			storage: a.storage.into_iter().fold(BTreeMap::new(), |mut acc, (key, value)| { | 			storage: a.storage.into_iter().fold(BTreeMap::new(), |mut acc, (key, value)| { | ||||||
| 				let key: U256 = key.into(); | 				let key: U256 = key.into(); | ||||||
| 				acc.insert(H256::from(key), value.into()); | 				let value: U256 = value.into(); | ||||||
|  | 				acc.insert(H256::from(key), H256::from(value)); | ||||||
| 				acc | 				acc | ||||||
| 			}) | 			}) | ||||||
| 		} | 		} | ||||||
|  | |||||||
| @ -21,7 +21,7 @@ use pod_account::*; | |||||||
| use ethjson; | use ethjson; | ||||||
| 
 | 
 | ||||||
| /// State of all accounts in the system expressed in Plain Old Data.
 | /// State of all accounts in the system expressed in Plain Old Data.
 | ||||||
| #[derive(Debug,Clone,PartialEq,Eq,Default)] | #[derive(Debug, Clone, PartialEq, Eq, Default)] | ||||||
| pub struct PodState (BTreeMap<Address, PodAccount>); | pub struct PodState (BTreeMap<Address, PodAccount>); | ||||||
| 
 | 
 | ||||||
| impl PodState { | impl PodState { | ||||||
|  | |||||||
| @ -19,7 +19,6 @@ | |||||||
| use std::collections::BTreeMap; | use std::collections::BTreeMap; | ||||||
| use uint::Uint; | use uint::Uint; | ||||||
| use bytes::Bytes; | use bytes::Bytes; | ||||||
| use hash::H256; |  | ||||||
| 
 | 
 | ||||||
| /// Blockchain test account deserializer.
 | /// Blockchain test account deserializer.
 | ||||||
| #[derive(Debug, PartialEq, Deserialize, Clone)] | #[derive(Debug, PartialEq, Deserialize, Clone)] | ||||||
| @ -31,7 +30,7 @@ pub struct Account { | |||||||
| 	/// Nonce.
 | 	/// Nonce.
 | ||||||
| 	pub nonce: Uint, | 	pub nonce: Uint, | ||||||
| 	/// Storage.
 | 	/// Storage.
 | ||||||
| 	pub storage: BTreeMap<Uint, H256>, | 	pub storage: BTreeMap<Uint, Uint>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #[cfg(test)] | #[cfg(test)] | ||||||
|  | |||||||
| @ -24,11 +24,11 @@ use blockchain::transaction::Transaction; | |||||||
| #[derive(Debug, PartialEq, Deserialize)] | #[derive(Debug, PartialEq, Deserialize)] | ||||||
| pub struct Block { | pub struct Block { | ||||||
| 	#[serde(rename="blockHeader")] | 	#[serde(rename="blockHeader")] | ||||||
| 	header: Header, | 	header: Option<Header>, | ||||||
| 	rlp: Bytes, | 	rlp: Bytes, | ||||||
| 	transactions: Vec<Transaction>, | 	transactions: Option<Vec<Transaction>>, | ||||||
| 	#[serde(rename="uncleHeaders")] | 	#[serde(rename="uncleHeaders")] | ||||||
| 	uncles: Vec<Header>, | 	uncles: Option<Vec<Header>>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Block { | impl Block { | ||||||
|  | |||||||
| @ -17,6 +17,7 @@ | |||||||
| //! Blockchain deserialization.
 | //! Blockchain deserialization.
 | ||||||
| 
 | 
 | ||||||
| use bytes::Bytes; | use bytes::Bytes; | ||||||
|  | use hash::H256; | ||||||
| use blockchain::state::State; | use blockchain::state::State; | ||||||
| use blockchain::header::Header; | use blockchain::header::Header; | ||||||
| use blockchain::block::Block; | use blockchain::block::Block; | ||||||
| @ -30,7 +31,7 @@ pub struct BlockChain { | |||||||
| 	pub genesis_block: Header, | 	pub genesis_block: Header, | ||||||
| 	/// Genesis block rlp.
 | 	/// Genesis block rlp.
 | ||||||
| 	#[serde(rename="genesisRLP")] | 	#[serde(rename="genesisRLP")] | ||||||
| 	pub genesis_rlp: Bytes, | 	pub genesis_rlp: Option<Bytes>, | ||||||
| 	/// Blocks.
 | 	/// Blocks.
 | ||||||
| 	pub blocks: Vec<Block>, | 	pub blocks: Vec<Block>, | ||||||
| 	/// Post state.
 | 	/// Post state.
 | ||||||
| @ -39,14 +40,12 @@ pub struct BlockChain { | |||||||
| 	/// Pre state.
 | 	/// Pre state.
 | ||||||
| 	#[serde(rename="pre")] | 	#[serde(rename="pre")] | ||||||
| 	pub pre_state: State, | 	pub pre_state: State, | ||||||
|  | 	/// Hash of best block.
 | ||||||
|  | 	#[serde(rename="lastblockhash")] | ||||||
|  | 	pub best_block: H256 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl BlockChain { | impl BlockChain { | ||||||
| 	/// Returns genesis block rlp.
 |  | ||||||
| 	pub fn genesis_rlp(&self) -> Vec<u8> { |  | ||||||
| 		self.genesis_rlp.clone().into() |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	/// Returns blocks rlp.
 | 	/// Returns blocks rlp.
 | ||||||
| 	pub fn blocks_rlp(&self) -> Vec<Vec<u8>> { | 	pub fn blocks_rlp(&self) -> Vec<Vec<u8>> { | ||||||
| 		self.blocks.iter().map(|block| block.rlp()).collect() | 		self.blocks.iter().map(|block| block.rlp()).collect() | ||||||
|  | |||||||
| @ -18,6 +18,9 @@ | |||||||
| 
 | 
 | ||||||
| use std::collections::BTreeMap; | use std::collections::BTreeMap; | ||||||
| use std::ops::Deref; | use std::ops::Deref; | ||||||
|  | use std::io::Read; | ||||||
|  | use serde_json; | ||||||
|  | use serde_json::Error; | ||||||
| use blockchain::blockchain::BlockChain; | use blockchain::blockchain::BlockChain; | ||||||
| 
 | 
 | ||||||
| /// Blockchain test deserializer.
 | /// Blockchain test deserializer.
 | ||||||
| @ -31,3 +34,10 @@ impl Deref for Test { | |||||||
| 		&self.0 | 		&self.0 | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | impl Test { | ||||||
|  | 	/// Loads test from json.
 | ||||||
|  | 	pub fn load<R>(reader: R) -> Result<Self, Error> where R: Read { | ||||||
|  | 		serde_json::from_reader(reader) | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | |||||||
| @ -46,12 +46,8 @@ impl Visitor for BytesVisitor { | |||||||
| 		let v = match value.len() { | 		let v = match value.len() { | ||||||
| 			0 => vec![], | 			0 => vec![], | ||||||
| 			2 if value.starts_with("0x") => vec![], | 			2 if value.starts_with("0x") => vec![], | ||||||
| 			_ if value.starts_with("0x") => try!(FromHex::from_hex(&value[2..]).map_err(|_| { | 			_ if value.starts_with("0x") => FromHex::from_hex(&value[2..]).unwrap_or(vec![]), | ||||||
| 				Error::custom(format!("Invalid hex value {}.", value).as_ref()) | 			_ => FromHex::from_hex(value).unwrap_or(vec![]), | ||||||
| 			})), |  | ||||||
| 			_ => try!(FromHex::from_hex(value).map_err(|_| { |  | ||||||
| 				Error::custom(format!("Invalid hex value {}.", value).as_ref()) |  | ||||||
| 			})) |  | ||||||
| 		}; | 		}; | ||||||
| 		Ok(Bytes(v)) | 		Ok(Bytes(v)) | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -37,9 +37,10 @@ use ethcore::ethereum; | |||||||
| use ethcore::client::{BlockChainClient, Client, ClientConfig}; | use ethcore::client::{BlockChainClient, Client, ClientConfig}; | ||||||
| use devtools::RandomTempPath; | use devtools::RandomTempPath; | ||||||
| use util::IoChannel; | use util::IoChannel; | ||||||
| use rpc::v1::tests::helpers::{TestSyncProvider, Config as SyncConfig, TestMinerService, TestAccountProvider}; | use rpc::v1::tests::helpers::{TestSyncProvider, Config as SyncConfig, TestMinerService, TestAccountProvider, TestAccount}; | ||||||
| use rpc::v1::{Eth, EthClient}; | use rpc::v1::{Eth, EthClient, EthFilter, EthFilterClient}; | ||||||
| use util::panics::MayPanic; | use util::panics::MayPanic; | ||||||
|  | use util::hash::Address; | ||||||
| 
 | 
 | ||||||
| const USAGE: &'static str = r#" | const USAGE: &'static str = r#" | ||||||
| Parity rpctest client. | Parity rpctest client. | ||||||
| @ -86,8 +87,9 @@ impl Configuration { | |||||||
| 			process::exit(1); | 			process::exit(1); | ||||||
| 		}); | 		}); | ||||||
| 
 | 
 | ||||||
| 		let	tests: ethjson::blockchain::Test = serde_json::from_reader(file).unwrap_or_else(|_| { | 		let	tests: ethjson::blockchain::Test = serde_json::from_reader(file).unwrap_or_else(|err| { | ||||||
| 			println!("Invalid json file."); | 			println!("Invalid json file."); | ||||||
|  | 			println!("{:?}", err); | ||||||
| 			process::exit(2); | 			process::exit(2); | ||||||
| 		}); | 		}); | ||||||
| 
 | 
 | ||||||
| @ -117,9 +119,12 @@ impl Configuration { | |||||||
| 			})); | 			})); | ||||||
| 
 | 
 | ||||||
| 			let miner = Arc::new(TestMinerService::default()); | 			let miner = Arc::new(TestMinerService::default()); | ||||||
| 			let accounts = Arc::new(TestAccountProvider::new(HashMap::new())); | 			let mut accs = HashMap::new(); | ||||||
|  | 			accs.insert(Address::from(1), TestAccount::new("test")); | ||||||
|  | 			let accounts = Arc::new(TestAccountProvider::new(accs)); | ||||||
| 			let server = rpc::RpcServer::new(); | 			let server = rpc::RpcServer::new(); | ||||||
| 			server.add_delegate(EthClient::new(&client, &sync, &accounts, &miner).to_delegate()); | 			server.add_delegate(EthClient::new(&client, &sync, &accounts, &miner).to_delegate()); | ||||||
|  | 			server.add_delegate(EthFilterClient::new(&client, &miner).to_delegate()); | ||||||
| 
 | 
 | ||||||
| 			let url = format!("{}:{}", self.args.flag_jsonrpc_addr, self.args.flag_jsonrpc_port); | 			let url = format!("{}:{}", self.args.flag_jsonrpc_addr, self.args.flag_jsonrpc_port); | ||||||
| 			let panic_handler = server.start_http(url.as_ref(), "*", 1); | 			let panic_handler = server.start_http(url.as_ref(), "*", 1); | ||||||
|  | |||||||
| @ -103,7 +103,8 @@ impl<C, S, A, M, EM> EthClient<C, S, A, M, EM> | |||||||
| 					timestamp: U256::from(view.timestamp()), | 					timestamp: U256::from(view.timestamp()), | ||||||
| 					difficulty: view.difficulty(), | 					difficulty: view.difficulty(), | ||||||
| 					total_difficulty: total_difficulty, | 					total_difficulty: total_difficulty, | ||||||
| 					uncles: vec![], | 					nonce: view.seal().get(1).map_or_else(H64::zero, |r| H64::from_slice(r)), | ||||||
|  | 					uncles: block_view.uncle_hashes(), | ||||||
| 					transactions: { | 					transactions: { | ||||||
| 						if include_txs { | 						if include_txs { | ||||||
| 							BlockTransactions::Full(block_view.localized_transactions().into_iter().map(From::from).collect()) | 							BlockTransactions::Full(block_view.localized_transactions().into_iter().map(From::from).collect()) | ||||||
| @ -111,7 +112,7 @@ impl<C, S, A, M, EM> EthClient<C, S, A, M, EM> | |||||||
| 							BlockTransactions::Hashes(block_view.transaction_hashes()) | 							BlockTransactions::Hashes(block_view.transaction_hashes()) | ||||||
| 						} | 						} | ||||||
| 					}, | 					}, | ||||||
| 					extra_data: Bytes::default() | 					extra_data: Bytes::new(view.extra_data()) | ||||||
| 				}; | 				}; | ||||||
| 				to_value(&block) | 				to_value(&block) | ||||||
| 			}, | 			}, | ||||||
| @ -229,8 +230,8 @@ impl<C, S, A, M, EM> Eth for EthClient<C, S, A, M, EM> | |||||||
| 	fn block_transaction_count_by_hash(&self, params: Params) -> Result<Value, Error> { | 	fn block_transaction_count_by_hash(&self, params: Params) -> Result<Value, Error> { | ||||||
| 		from_params::<(H256,)>(params) | 		from_params::<(H256,)>(params) | ||||||
| 			.and_then(|(hash,)| // match
 | 			.and_then(|(hash,)| // match
 | ||||||
| 				to_value(&take_weak!(self.client).block(BlockId::Hash(hash)) | 				take_weak!(self.client).block(BlockId::Hash(hash)) | ||||||
| 					.map_or_else(U256::zero, |bytes| U256::from(BlockView::new(&bytes).transactions_count())))) | 					.map_or(Ok(Value::Null), |bytes| to_value(&U256::from(BlockView::new(&bytes).transactions_count())))) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn block_transaction_count_by_number(&self, params: Params) -> Result<Value, Error> { | 	fn block_transaction_count_by_number(&self, params: Params) -> Result<Value, Error> { | ||||||
| @ -239,24 +240,24 @@ impl<C, S, A, M, EM> Eth for EthClient<C, S, A, M, EM> | |||||||
| 				BlockNumber::Pending => to_value( | 				BlockNumber::Pending => to_value( | ||||||
| 					&U256::from(take_weak!(self.miner).status().transactions_in_pending_block) | 					&U256::from(take_weak!(self.miner).status().transactions_in_pending_block) | ||||||
| 				), | 				), | ||||||
| 				_ => to_value(&take_weak!(self.client).block(block_number.into()) | 				_ => take_weak!(self.client).block(block_number.into()) | ||||||
| 						.map_or_else(U256::zero, |bytes| U256::from(BlockView::new(&bytes).transactions_count()))) | 						.map_or(Ok(Value::Null), |bytes| to_value(&U256::from(BlockView::new(&bytes).transactions_count()))) | ||||||
| 			}) | 			}) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn block_uncles_count_by_hash(&self, params: Params) -> Result<Value, Error> { | 	fn block_uncles_count_by_hash(&self, params: Params) -> Result<Value, Error> { | ||||||
| 		from_params::<(H256,)>(params) | 		from_params::<(H256,)>(params) | ||||||
| 			.and_then(|(hash,)| | 			.and_then(|(hash,)| | ||||||
| 				to_value(&take_weak!(self.client).block(BlockId::Hash(hash)) | 				take_weak!(self.client).block(BlockId::Hash(hash)) | ||||||
| 					.map_or_else(U256::zero, |bytes| U256::from(BlockView::new(&bytes).uncles_count())))) | 					.map_or(Ok(Value::Null), |bytes| to_value(&U256::from(BlockView::new(&bytes).uncles_count())))) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn block_uncles_count_by_number(&self, params: Params) -> Result<Value, Error> { | 	fn block_uncles_count_by_number(&self, params: Params) -> Result<Value, Error> { | ||||||
| 		from_params::<(BlockNumber,)>(params) | 		from_params::<(BlockNumber,)>(params) | ||||||
| 			.and_then(|(block_number,)| match block_number { | 			.and_then(|(block_number,)| match block_number { | ||||||
| 				BlockNumber::Pending => to_value(&U256::from(0)), | 				BlockNumber::Pending => to_value(&U256::from(0)), | ||||||
| 				_ => to_value(&take_weak!(self.client).block(block_number.into()) | 				_ => take_weak!(self.client).block(block_number.into()) | ||||||
| 						.map_or_else(U256::zero, |bytes| U256::from(BlockView::new(&bytes).uncles_count()))) | 						.map_or(Ok(Value::Null), |bytes| to_value(&U256::from(BlockView::new(&bytes).uncles_count()))) | ||||||
| 			}) | 			}) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -224,7 +224,7 @@ fn rpc_eth_block_transaction_count_by_hash() { | |||||||
| 		"params": ["0xb903239f8543d04b5dc1ba6579132b143087c68db1b2168786408fcbce568238"], | 		"params": ["0xb903239f8543d04b5dc1ba6579132b143087c68db1b2168786408fcbce568238"], | ||||||
| 		"id": 1 | 		"id": 1 | ||||||
| 	}"#;
 | 	}"#;
 | ||||||
| 	let response = r#"{"jsonrpc":"2.0","result":"0x00","id":1}"#; | 	let response = r#"{"jsonrpc":"2.0","result":null,"id":1}"#; | ||||||
| 
 | 
 | ||||||
| 	assert_eq!(EthTester::default().io.handle_request(request), Some(response.to_owned())); | 	assert_eq!(EthTester::default().io.handle_request(request), Some(response.to_owned())); | ||||||
| } | } | ||||||
| @ -264,7 +264,7 @@ fn rpc_eth_uncle_count_by_block_hash() { | |||||||
| 		"params": ["0xb903239f8543d04b5dc1ba6579132b143087c68db1b2168786408fcbce568238"], | 		"params": ["0xb903239f8543d04b5dc1ba6579132b143087c68db1b2168786408fcbce568238"], | ||||||
| 		"id": 1 | 		"id": 1 | ||||||
| 	}"#;
 | 	}"#;
 | ||||||
| 	let response = r#"{"jsonrpc":"2.0","result":"0x00","id":1}"#; | 	let response = r#"{"jsonrpc":"2.0","result":null,"id":1}"#; | ||||||
| 
 | 
 | ||||||
| 	assert_eq!(EthTester::default().io.handle_request(request), Some(response.to_owned())); | 	assert_eq!(EthTester::default().io.handle_request(request), Some(response.to_owned())); | ||||||
| } | } | ||||||
|  | |||||||
| @ -57,7 +57,7 @@ impl MinerService for TestMinerService { | |||||||
| 		where T: Fn(&Address) -> AccountDetails { unimplemented!(); } | 		where T: Fn(&Address) -> AccountDetails { unimplemented!(); } | ||||||
| 
 | 
 | ||||||
| 	/// Returns hashes of transactions currently in pending
 | 	/// Returns hashes of transactions currently in pending
 | ||||||
| 	fn pending_transactions_hashes(&self) -> Vec<H256> { unimplemented!(); } | 	fn pending_transactions_hashes(&self) -> Vec<H256> { vec![] } | ||||||
| 
 | 
 | ||||||
| 	/// Removes all transactions from the queue and restart mining operation.
 | 	/// Removes all transactions from the queue and restart mining operation.
 | ||||||
| 	fn clear_and_reset(&self, _chain: &BlockChainClient) { unimplemented!(); } | 	fn clear_and_reset(&self, _chain: &BlockChainClient) { unimplemented!(); } | ||||||
|  | |||||||
| @ -63,7 +63,8 @@ pub struct Block { | |||||||
| 	pub difficulty: U256, | 	pub difficulty: U256, | ||||||
| 	#[serde(rename="totalDifficulty")] | 	#[serde(rename="totalDifficulty")] | ||||||
| 	pub total_difficulty: U256, | 	pub total_difficulty: U256, | ||||||
| 	pub uncles: Vec<U256>, | 	pub nonce: H64, | ||||||
|  | 	pub uncles: Vec<H256>, | ||||||
| 	pub transactions: BlockTransactions | 	pub transactions: BlockTransactions | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -78,7 +79,7 @@ mod tests { | |||||||
| 	fn test_serialize_block_transactions() { | 	fn test_serialize_block_transactions() { | ||||||
| 		let t = BlockTransactions::Full(vec![Transaction::default()]); | 		let t = BlockTransactions::Full(vec![Transaction::default()]); | ||||||
| 		let serialized = serde_json::to_string(&t).unwrap(); | 		let serialized = serde_json::to_string(&t).unwrap(); | ||||||
| 		assert_eq!(serialized, r#"[{"hash":"0x0000000000000000000000000000000000000000000000000000000000000000","nonce":"0x00","blockHash":null,"blockNumber":null,"transactionIndex":null,"from":"0x0000000000000000000000000000000000000000","to":null,"value":"0x00","gasPrice":"0x00","gas":"0x00","input":"0x00"}]"#); | 		assert_eq!(serialized, r#"[{"hash":"0x0000000000000000000000000000000000000000000000000000000000000000","nonce":"0x00","blockHash":null,"blockNumber":null,"transactionIndex":null,"from":"0x0000000000000000000000000000000000000000","to":null,"value":"0x00","gasPrice":"0x00","gas":"0x00","input":"0x"}]"#); | ||||||
| 
 | 
 | ||||||
| 		let t = BlockTransactions::Hashes(vec![H256::default()]); | 		let t = BlockTransactions::Hashes(vec![H256::default()]); | ||||||
| 		let serialized = serde_json::to_string(&t).unwrap(); | 		let serialized = serde_json::to_string(&t).unwrap(); | ||||||
| @ -104,11 +105,12 @@ mod tests { | |||||||
| 			timestamp: U256::default(), | 			timestamp: U256::default(), | ||||||
| 			difficulty: U256::default(), | 			difficulty: U256::default(), | ||||||
| 			total_difficulty: U256::default(), | 			total_difficulty: U256::default(), | ||||||
|  | 			nonce: H64::default(), | ||||||
| 			uncles: vec![], | 			uncles: vec![], | ||||||
| 			transactions: BlockTransactions::Hashes(vec![]) | 			transactions: BlockTransactions::Hashes(vec![]) | ||||||
| 		}; | 		}; | ||||||
| 
 | 
 | ||||||
| 		let serialized = serde_json::to_string(&block).unwrap(); | 		let serialized = serde_json::to_string(&block).unwrap(); | ||||||
| 		assert_eq!(serialized, r#"{"hash":"0x0000000000000000000000000000000000000000000000000000000000000000","parentHash":"0x0000000000000000000000000000000000000000000000000000000000000000","sha3Uncles":"0x0000000000000000000000000000000000000000000000000000000000000000","author":"0x0000000000000000000000000000000000000000","miner":"0x0000000000000000000000000000000000000000","stateRoot":"0x0000000000000000000000000000000000000000000000000000000000000000","transactionsRoot":"0x0000000000000000000000000000000000000000000000000000000000000000","receiptsRoot":"0x0000000000000000000000000000000000000000000000000000000000000000","number":"0x00","gasUsed":"0x00","gasLimit":"0x00","extraData":"0x00","logsBloom":"0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000","timestamp":"0x00","difficulty":"0x00","totalDifficulty":"0x00","uncles":[],"transactions":[]}"#); | 		assert_eq!(serialized, r#"{"hash":"0x0000000000000000000000000000000000000000000000000000000000000000","parentHash":"0x0000000000000000000000000000000000000000000000000000000000000000","sha3Uncles":"0x0000000000000000000000000000000000000000000000000000000000000000","author":"0x0000000000000000000000000000000000000000","miner":"0x0000000000000000000000000000000000000000","stateRoot":"0x0000000000000000000000000000000000000000000000000000000000000000","transactionsRoot":"0x0000000000000000000000000000000000000000000000000000000000000000","receiptsRoot":"0x0000000000000000000000000000000000000000000000000000000000000000","number":"0x00","gasUsed":"0x00","gasLimit":"0x00","extraData":"0x","logsBloom":"0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000","timestamp":"0x00","difficulty":"0x00","totalDifficulty":"0x00","nonce":"0x0000000000000000","uncles":[],"transactions":[]}"#); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | |||||||
| @ -20,7 +20,7 @@ use serde::de::Visitor; | |||||||
| use util::common::FromHex; | use util::common::FromHex; | ||||||
| 
 | 
 | ||||||
| /// Wrapper structure around vector of bytes.
 | /// Wrapper structure around vector of bytes.
 | ||||||
| #[derive(Debug, PartialEq)] | #[derive(Debug, PartialEq, Default)] | ||||||
| pub struct Bytes(Vec<u8>); | pub struct Bytes(Vec<u8>); | ||||||
| 
 | 
 | ||||||
| impl Bytes { | impl Bytes { | ||||||
| @ -31,13 +31,6 @@ impl Bytes { | |||||||
| 	pub fn to_vec(self) -> Vec<u8> { let Bytes(x) = self; x } | 	pub fn to_vec(self) -> Vec<u8> { let Bytes(x) = self; x } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Default for Bytes { |  | ||||||
| 	fn default() -> Self { |  | ||||||
| 		// default serialized value is 0x00
 |  | ||||||
| 		Bytes(vec![0]) |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| impl Serialize for Bytes { | impl Serialize for Bytes { | ||||||
| 	fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error> | 	fn serialize<S>(&self, serializer: &mut S) -> Result<(), S::Error> | ||||||
| 	where S: Serializer { | 	where S: Serializer { | ||||||
|  | |||||||
| @ -67,7 +67,7 @@ mod tests { | |||||||
| 	fn test_transaction_serialize() { | 	fn test_transaction_serialize() { | ||||||
| 		let t = Transaction::default(); | 		let t = Transaction::default(); | ||||||
| 		let serialized = serde_json::to_string(&t).unwrap(); | 		let serialized = serde_json::to_string(&t).unwrap(); | ||||||
| 		assert_eq!(serialized, r#"{"hash":"0x0000000000000000000000000000000000000000000000000000000000000000","nonce":"0x00","blockHash":null,"blockNumber":null,"transactionIndex":null,"from":"0x0000000000000000000000000000000000000000","to":null,"value":"0x00","gasPrice":"0x00","gas":"0x00","input":"0x00"}"#); | 		assert_eq!(serialized, r#"{"hash":"0x0000000000000000000000000000000000000000000000000000000000000000","nonce":"0x00","blockHash":null,"blockNumber":null,"transactionIndex":null,"from":"0x0000000000000000000000000000000000000000","to":null,"value":"0x00","gasPrice":"0x00","gas":"0x00","input":"0x"}"#); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user