Merge branch 'master' into tx_queue_gas_limit
Conflicts: miner/src/transaction_queue.rs
This commit is contained in:
		
						commit
						58bb5e967a
					
				
							
								
								
									
										30
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										30
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @ -2,7 +2,7 @@ | |||||||
| name = "parity" | name = "parity" | ||||||
| version = "1.1.0" | version = "1.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "clippy 0.0.50 (registry+https://github.com/rust-lang/crates.io-index)", |  "clippy 0.0.54 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "ctrlc 1.1.1 (git+https://github.com/tomusdrw/rust-ctrlc.git)", |  "ctrlc 1.1.1 (git+https://github.com/tomusdrw/rust-ctrlc.git)", | ||||||
|  "daemonize 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "daemonize 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "docopt 0.6.78 (registry+https://github.com/rust-lang/crates.io-index)", |  "docopt 0.6.78 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -96,11 +96,12 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "clippy" | name = "clippy" | ||||||
| version = "0.0.50" | version = "0.0.54" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "regex-syntax 0.2.5 (registry+https://github.com/rust-lang/crates.io-index)", |  "regex-syntax 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "semver 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", |  "semver 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "toml 0.1.28 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "unicode-normalization 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "unicode-normalization 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -209,7 +210,7 @@ dependencies = [ | |||||||
| name = "ethcore" | name = "ethcore" | ||||||
| version = "1.1.0" | version = "1.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "clippy 0.0.50 (registry+https://github.com/rust-lang/crates.io-index)", |  "clippy 0.0.54 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "crossbeam 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "crossbeam 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "env_logger 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "env_logger 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "ethash 1.1.0", |  "ethash 1.1.0", | ||||||
| @ -235,7 +236,7 @@ dependencies = [ | |||||||
| name = "ethcore-rpc" | name = "ethcore-rpc" | ||||||
| version = "1.1.0" | version = "1.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "clippy 0.0.50 (registry+https://github.com/rust-lang/crates.io-index)", |  "clippy 0.0.54 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "ethash 1.1.0", |  "ethash 1.1.0", | ||||||
|  "ethcore 1.1.0", |  "ethcore 1.1.0", | ||||||
|  "ethcore-util 1.1.0", |  "ethcore-util 1.1.0", | ||||||
| @ -259,7 +260,7 @@ dependencies = [ | |||||||
|  "arrayvec 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)", |  "arrayvec 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "bigint 0.1.0", |  "bigint 0.1.0", | ||||||
|  "chrono 0.2.20 (registry+https://github.com/rust-lang/crates.io-index)", |  "chrono 0.2.20 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "clippy 0.0.50 (registry+https://github.com/rust-lang/crates.io-index)", |  "clippy 0.0.54 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "crossbeam 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", |  "crossbeam 0.2.8 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "elastic-array 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "elastic-array 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "env_logger 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "env_logger 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -303,7 +304,7 @@ dependencies = [ | |||||||
| name = "ethminer" | name = "ethminer" | ||||||
| version = "1.1.0" | version = "1.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "clippy 0.0.50 (registry+https://github.com/rust-lang/crates.io-index)", |  "clippy 0.0.54 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "env_logger 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "env_logger 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "ethcore 1.1.0", |  "ethcore 1.1.0", | ||||||
|  "ethcore-util 1.1.0", |  "ethcore-util 1.1.0", | ||||||
| @ -317,7 +318,7 @@ dependencies = [ | |||||||
| name = "ethsync" | name = "ethsync" | ||||||
| version = "1.1.0" | version = "1.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "clippy 0.0.50 (registry+https://github.com/rust-lang/crates.io-index)", |  "clippy 0.0.54 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "env_logger 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "env_logger 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "ethcore 1.1.0", |  "ethcore 1.1.0", | ||||||
|  "ethcore-util 1.1.0", |  "ethcore-util 1.1.0", | ||||||
| @ -709,11 +710,6 @@ dependencies = [ | |||||||
|  "utf8-ranges 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)", |  "utf8-ranges 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "regex-syntax" |  | ||||||
| version = "0.2.5" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "regex-syntax" | name = "regex-syntax" | ||||||
| version = "0.3.0" | version = "0.3.0" | ||||||
| @ -895,6 +891,14 @@ name = "tiny-keccak" | |||||||
| version = "1.0.5" | version = "1.0.5" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "toml" | ||||||
|  | version = "0.1.28" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "rustc-serialize 0.3.18 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "traitobject" | name = "traitobject" | ||||||
| version = "0.0.1" | version = "0.0.1" | ||||||
|  | |||||||
| @ -20,7 +20,7 @@ fdlimit = { path = "util/fdlimit" } | |||||||
| daemonize = "0.2" | daemonize = "0.2" | ||||||
| number_prefix = "0.2" | number_prefix = "0.2" | ||||||
| rpassword = "0.1" | rpassword = "0.1" | ||||||
| clippy = { version = "0.0.50", optional = true } | clippy = { version = "0.0.54", optional = true } | ||||||
| ethcore = { path = "ethcore" } | ethcore = { path = "ethcore" } | ||||||
| ethcore-util = { path = "util" } | ethcore-util = { path = "util" } | ||||||
| ethsync = { path = "sync" } | ethsync = { path = "sync" } | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ ethcore-util = { path = "../util" } | |||||||
| evmjit = { path = "../evmjit", optional = true } | evmjit = { path = "../evmjit", optional = true } | ||||||
| ethash = { path = "../ethash" } | ethash = { path = "../ethash" } | ||||||
| num_cpus = "0.2" | num_cpus = "0.2" | ||||||
| clippy = { version = "0.0.50", optional = true } | clippy = { version = "0.0.54", optional = true } | ||||||
| crossbeam = "0.1.5" | crossbeam = "0.1.5" | ||||||
| lazy_static = "0.1" | lazy_static = "0.1" | ||||||
| ethcore-devtools = { path = "../devtools" } | ethcore-devtools = { path = "../devtools" } | ||||||
|  | |||||||
| @ -67,6 +67,7 @@ pub trait Ext { | |||||||
| 	/// Returns Err, if we run out of gas.
 | 	/// Returns Err, if we run out of gas.
 | ||||||
| 	/// Otherwise returns call_result which contains gas left
 | 	/// Otherwise returns call_result which contains gas left
 | ||||||
| 	/// and true if subcall was successfull.
 | 	/// and true if subcall was successfull.
 | ||||||
|  | 	#[cfg_attr(feature="dev", allow(too_many_arguments))] | ||||||
| 	fn call(&mut self, | 	fn call(&mut self, | ||||||
| 			gas: &U256, | 			gas: &U256, | ||||||
| 			sender_address: &Address, | 			sender_address: &Address, | ||||||
|  | |||||||
| @ -521,6 +521,7 @@ impl Interpreter { | |||||||
| 		Ok(overflowing!(offset.overflowing_add(size.clone()))) | 		Ok(overflowing!(offset.overflowing_add(size.clone()))) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	#[cfg_attr(feature="dev", allow(too_many_arguments))] | ||||||
| 	fn exec_instruction(&self, | 	fn exec_instruction(&self, | ||||||
| 						gas: Gas, | 						gas: Gas, | ||||||
| 						params: &ActionParams, | 						params: &ActionParams, | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ rustc-serialize = "0.3" | |||||||
| serde = "0.7.0" | serde = "0.7.0" | ||||||
| serde_json = "0.7.0" | serde_json = "0.7.0" | ||||||
| serde_macros = { version = "0.7.0", optional = true } | serde_macros = { version = "0.7.0", optional = true } | ||||||
| clippy = { version = "0.0.50", optional = true } | clippy = { version = "0.0.54", optional = true } | ||||||
| 
 | 
 | ||||||
| [build-dependencies] | [build-dependencies] | ||||||
| serde_codegen = { version = "0.7.0", optional = true } | serde_codegen = { version = "0.7.0", optional = true } | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ log = "0.3" | |||||||
| env_logger = "0.3" | env_logger = "0.3" | ||||||
| rustc-serialize = "0.3" | rustc-serialize = "0.3" | ||||||
| rayon = "0.3.1" | rayon = "0.3.1" | ||||||
| clippy = { version = "0.0.50", optional = true } | clippy = { version = "0.0.54", optional = true } | ||||||
| 
 | 
 | ||||||
| [features] | [features] | ||||||
| default = [] | default = [] | ||||||
|  | |||||||
| @ -131,10 +131,7 @@ impl MinerService for Miner { | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn prepare_sealing(&self, chain: &BlockChainClient) { | 	fn prepare_sealing(&self, chain: &BlockChainClient) { | ||||||
| 		let no_of_transactions = 128; | 		let transactions = self.transaction_queue.lock().unwrap().top_transactions(); | ||||||
| 		// TODO: should select transactions orm queue according to gas limit of block.
 |  | ||||||
| 		let transactions = self.transaction_queue.lock().unwrap().top_transactions(no_of_transactions); |  | ||||||
| 
 |  | ||||||
| 		let b = chain.prepare_sealing( | 		let b = chain.prepare_sealing( | ||||||
| 			self.author(), | 			self.author(), | ||||||
| 			self.gas_floor_target(), | 			self.gas_floor_target(), | ||||||
|  | |||||||
| @ -59,7 +59,7 @@ | |||||||
| //!		// Check status
 | //!		// Check status
 | ||||||
| //!		assert_eq!(txq.status().pending, 2);
 | //!		assert_eq!(txq.status().pending, 2);
 | ||||||
| //!		// Check top transactions
 | //!		// Check top transactions
 | ||||||
| //!		let top = txq.top_transactions(3);
 | //!		let top = txq.top_transactions();
 | ||||||
| //!		assert_eq!(top.len(), 2);
 | //!		assert_eq!(top.len(), 2);
 | ||||||
| //!		assert_eq!(top[0], st1);
 | //!		assert_eq!(top[0], st1);
 | ||||||
| //!		assert_eq!(top[1], st2);
 | //!		assert_eq!(top[1], st2);
 | ||||||
| @ -69,7 +69,7 @@ | |||||||
| //!		txq.remove(&st1.hash(), &default_nonce);
 | //!		txq.remove(&st1.hash(), &default_nonce);
 | ||||||
| //!		assert_eq!(txq.status().pending, 0);
 | //!		assert_eq!(txq.status().pending, 0);
 | ||||||
| //!		assert_eq!(txq.status().future, 1);
 | //!		assert_eq!(txq.status().future, 1);
 | ||||||
| //!		assert_eq!(txq.top_transactions(3).len(), 0);
 | //!		assert_eq!(txq.top_transactions().len(), 0);
 | ||||||
| //!	}
 | //!	}
 | ||||||
| //! ```
 | //! ```
 | ||||||
| //!
 | //!
 | ||||||
| @ -324,8 +324,6 @@ impl TransactionQueue { | |||||||
| 		}; | 		}; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Will be used when rpc merged
 |  | ||||||
| 	#[allow(dead_code)] |  | ||||||
| 	/// Returns current status for this queue
 | 	/// Returns current status for this queue
 | ||||||
| 	pub fn status(&self) -> TransactionQueueStatus { | 	pub fn status(&self) -> TransactionQueueStatus { | ||||||
| 		TransactionQueueStatus { | 		TransactionQueueStatus { | ||||||
| @ -486,13 +484,10 @@ impl TransactionQueue { | |||||||
| 		self.future.enforce_limit(&mut self.by_hash); | 		self.future.enforce_limit(&mut self.by_hash); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Will be used when mining merged
 |  | ||||||
| 	#[allow(dead_code)] |  | ||||||
| 	/// Returns top transactions from the queue ordered by priority.
 | 	/// Returns top transactions from the queue ordered by priority.
 | ||||||
| 	pub fn top_transactions(&self, size: usize) -> Vec<SignedTransaction> { | 	pub fn top_transactions(&self) -> Vec<SignedTransaction> { | ||||||
| 		self.current.by_priority | 		self.current.by_priority | ||||||
| 			.iter() | 			.iter() | ||||||
| 			.take(size) |  | ||||||
| 			.map(|t| self.by_hash.get(&t.hash).expect("Transaction Queue Inconsistency")) | 			.map(|t| self.by_hash.get(&t.hash).expect("Transaction Queue Inconsistency")) | ||||||
| 			.map(|t| t.transaction.clone()) | 			.map(|t| t.transaction.clone()) | ||||||
| 			.collect() | 			.collect() | ||||||
| @ -815,7 +810,7 @@ mod test { | |||||||
| 		txq.add(tx2.clone(), &default_nonce).unwrap(); | 		txq.add(tx2.clone(), &default_nonce).unwrap(); | ||||||
| 
 | 
 | ||||||
| 		// then
 | 		// then
 | ||||||
| 		let top = txq.top_transactions(5); | 		let top = txq.top_transactions(); | ||||||
| 		assert_eq!(top[0], tx); | 		assert_eq!(top[0], tx); | ||||||
| 		assert_eq!(top[1], tx2); | 		assert_eq!(top[1], tx2); | ||||||
| 		assert_eq!(top.len(), 2); | 		assert_eq!(top.len(), 2); | ||||||
| @ -854,7 +849,7 @@ mod test { | |||||||
| 		let stats = txq.status(); | 		let stats = txq.status(); | ||||||
| 		assert_eq!(stats.pending, 1); | 		assert_eq!(stats.pending, 1); | ||||||
| 		assert_eq!(stats.future, 1); | 		assert_eq!(stats.future, 1); | ||||||
| 		let top = txq.top_transactions(5); | 		let top = txq.top_transactions(); | ||||||
| 		assert_eq!(top.len(), 1); | 		assert_eq!(top.len(), 1); | ||||||
| 		assert_eq!(top[0], tx); | 		assert_eq!(top[0], tx); | ||||||
| 	} | 	} | ||||||
| @ -981,7 +976,7 @@ mod test { | |||||||
| 		txq.add(tx2.clone(), &default_nonce).unwrap(); | 		txq.add(tx2.clone(), &default_nonce).unwrap(); | ||||||
| 
 | 
 | ||||||
| 		// then
 | 		// then
 | ||||||
| 		let t = txq.top_transactions(2); | 		let t = txq.top_transactions(); | ||||||
| 		assert_eq!(txq.status().pending, 1); | 		assert_eq!(txq.status().pending, 1); | ||||||
| 		assert_eq!(t.len(), 1); | 		assert_eq!(t.len(), 1); | ||||||
| 		assert_eq!(t[0], tx); | 		assert_eq!(t[0], tx); | ||||||
| @ -1105,7 +1100,7 @@ mod test { | |||||||
| 		let stats = txq.status(); | 		let stats = txq.status(); | ||||||
| 		assert_eq!(stats.pending, 1); | 		assert_eq!(stats.pending, 1); | ||||||
| 		assert_eq!(stats.future, 0); | 		assert_eq!(stats.future, 0); | ||||||
| 		assert_eq!(txq.top_transactions(1)[0].gas_price, U256::from(200)); | 		assert_eq!(txq.top_transactions()[0].gas_price, U256::from(200)); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	#[test] | 	#[test] | ||||||
| @ -1135,7 +1130,7 @@ mod test { | |||||||
| 		let stats = txq.status(); | 		let stats = txq.status(); | ||||||
| 		assert_eq!(stats.future, 0); | 		assert_eq!(stats.future, 0); | ||||||
| 		assert_eq!(stats.pending, 2); | 		assert_eq!(stats.pending, 2); | ||||||
| 		assert_eq!(txq.top_transactions(2)[1].gas_price, U256::from(200)); | 		assert_eq!(txq.top_transactions()[1].gas_price, U256::from(200)); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	#[test] | 	#[test] | ||||||
|  | |||||||
| @ -370,7 +370,7 @@ impl Configuration { | |||||||
| 
 | 
 | ||||||
| 	fn init_nodes(&self, spec: &Spec) -> Vec<String> { | 	fn init_nodes(&self, spec: &Spec) -> Vec<String> { | ||||||
| 		match self.args.flag_bootnodes { | 		match self.args.flag_bootnodes { | ||||||
| 			Some(ref x) if x.len() > 0 => x.split(',').map(|s| { | 			Some(ref x) if !x.is_empty() => x.split(',').map(|s| { | ||||||
| 				Self::normalize_enode(s).unwrap_or_else(|| { | 				Self::normalize_enode(s).unwrap_or_else(|| { | ||||||
| 					die!("{}: Invalid node address format given for a boot node.", s) | 					die!("{}: Invalid node address format given for a boot node.", s) | ||||||
| 				}) | 				}) | ||||||
| @ -409,6 +409,7 @@ impl Configuration { | |||||||
| 		ret | 		ret | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	#[cfg_attr(feature="dev", allow(useless_format))] | ||||||
| 	fn client_config(&self) -> ClientConfig { | 	fn client_config(&self) -> ClientConfig { | ||||||
| 		let mut client_config = ClientConfig::default(); | 		let mut client_config = ClientConfig::default(); | ||||||
| 		match self.args.flag_cache { | 		match self.args.flag_cache { | ||||||
|  | |||||||
| @ -22,7 +22,7 @@ ethminer = { path = "../miner" } | |||||||
| rustc-serialize = "0.3" | rustc-serialize = "0.3" | ||||||
| transient-hashmap = "0.1" | transient-hashmap = "0.1" | ||||||
| serde_macros = { version = "0.7.0", optional = true } | serde_macros = { version = "0.7.0", optional = true } | ||||||
| clippy = { version = "0.0.50", optional = true } | clippy = { version = "0.0.54", optional = true } | ||||||
| 
 | 
 | ||||||
| [build-dependencies] | [build-dependencies] | ||||||
| serde_codegen = { version = "0.7.0", optional = true } | serde_codegen = { version = "0.7.0", optional = true } | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ authors = ["Ethcore <admin@ethcore.io"] | |||||||
| [dependencies] | [dependencies] | ||||||
| ethcore-util = { path = "../util" } | ethcore-util = { path = "../util" } | ||||||
| ethcore = { path = "../ethcore" } | ethcore = { path = "../ethcore" } | ||||||
| clippy = { version = "0.0.50", optional = true } | clippy = { version = "0.0.54", optional = true } | ||||||
| ethminer = { path = "../miner" } | ethminer = { path = "../miner" } | ||||||
| log = "0.3" | log = "0.3" | ||||||
| env_logger = "0.3" | env_logger = "0.3" | ||||||
|  | |||||||
| @ -937,6 +937,11 @@ impl ChainSync { | |||||||
| 	} | 	} | ||||||
| 	/// Called when peer sends us new transactions
 | 	/// Called when peer sends us new transactions
 | ||||||
| 	fn on_peer_transactions(&mut self, io: &mut SyncIo, peer_id: PeerId, r: &UntrustedRlp) -> Result<(), PacketDecodeError> { | 	fn on_peer_transactions(&mut self, io: &mut SyncIo, peer_id: PeerId, r: &UntrustedRlp) -> Result<(), PacketDecodeError> { | ||||||
|  | 		// accepting transactions once only fully synced
 | ||||||
|  | 		if !io.is_chain_queue_empty() { | ||||||
|  | 			return Ok(()); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		let item_count = r.item_count(); | 		let item_count = r.item_count(); | ||||||
| 		trace!(target: "sync", "{} -> Transactions ({} entries)", peer_id, item_count); | 		trace!(target: "sync", "{} -> Transactions ({} entries)", peer_id, item_count); | ||||||
| 
 | 
 | ||||||
| @ -1282,10 +1287,12 @@ impl ChainSync { | |||||||
| 
 | 
 | ||||||
| 	/// called when block is imported to chain, updates transactions queue and propagates the blocks
 | 	/// called when block is imported to chain, updates transactions queue and propagates the blocks
 | ||||||
| 	pub fn chain_new_blocks(&mut self, io: &mut SyncIo, imported: &[H256], invalid: &[H256], enacted: &[H256], retracted: &[H256]) { | 	pub fn chain_new_blocks(&mut self, io: &mut SyncIo, imported: &[H256], invalid: &[H256], enacted: &[H256], retracted: &[H256]) { | ||||||
| 		// Notify miner
 | 		if io.is_chain_queue_empty() { | ||||||
| 		self.miner.chain_new_blocks(io.chain(), imported, invalid, enacted, retracted); | 			// Notify miner
 | ||||||
| 		// Propagate latests blocks
 | 			self.miner.chain_new_blocks(io.chain(), imported, invalid, enacted, retracted); | ||||||
| 		self.propagate_latest_blocks(io); | 			// Propagate latests blocks
 | ||||||
|  | 			self.propagate_latest_blocks(io); | ||||||
|  | 		} | ||||||
| 		// TODO [todr] propagate transactions?
 | 		// TODO [todr] propagate transactions?
 | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -1654,6 +1661,33 @@ mod tests { | |||||||
| 		assert_eq!(status.transactions_in_future_queue, 0); | 		assert_eq!(status.transactions_in_future_queue, 0); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	#[test] | ||||||
|  | 	fn should_not_add_transactions_to_queue_if_not_synced() { | ||||||
|  | 		// given
 | ||||||
|  | 		let mut client = TestBlockChainClient::new(); | ||||||
|  | 		client.add_blocks(98, EachBlockWith::Uncle); | ||||||
|  | 		client.add_blocks(1, EachBlockWith::UncleAndTransaction); | ||||||
|  | 		client.add_blocks(1, EachBlockWith::Transaction); | ||||||
|  | 		let mut sync = dummy_sync_with_peer(client.block_hash_delta_minus(5)); | ||||||
|  | 
 | ||||||
|  | 		let good_blocks = vec![client.block_hash_delta_minus(2)]; | ||||||
|  | 		let retracted_blocks = vec![client.block_hash_delta_minus(1)]; | ||||||
|  | 
 | ||||||
|  | 		let mut queue = VecDeque::new(); | ||||||
|  | 		let mut io = TestIo::new(&mut client, &mut queue, None); | ||||||
|  | 
 | ||||||
|  | 		// when
 | ||||||
|  | 		sync.chain_new_blocks(&mut io, &[], &[], &[], &good_blocks); | ||||||
|  | 		assert_eq!(sync.miner.status().transactions_in_future_queue, 0); | ||||||
|  | 		assert_eq!(sync.miner.status().transactions_in_pending_queue, 0); | ||||||
|  | 		sync.chain_new_blocks(&mut io, &good_blocks, &[], &[], &retracted_blocks); | ||||||
|  | 
 | ||||||
|  | 		// then
 | ||||||
|  | 		let status = sync.miner.status(); | ||||||
|  | 		assert_eq!(status.transactions_in_pending_queue, 0); | ||||||
|  | 		assert_eq!(status.transactions_in_future_queue, 0); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	#[test] | 	#[test] | ||||||
| 	fn returns_requested_block_headers() { | 	fn returns_requested_block_headers() { | ||||||
| 		let mut client = TestBlockChainClient::new(); | 		let mut client = TestBlockChainClient::new(); | ||||||
|  | |||||||
| @ -37,6 +37,10 @@ pub trait SyncIo { | |||||||
| 	fn peer_info(&self, peer_id: PeerId) -> String { | 	fn peer_info(&self, peer_id: PeerId) -> String { | ||||||
| 		peer_id.to_string() | 		peer_id.to_string() | ||||||
| 	} | 	} | ||||||
|  | 	/// Returns if the chain block queue empty
 | ||||||
|  | 	fn is_chain_queue_empty(&self) -> bool { | ||||||
|  | 		self.chain().queue_info().is_empty() | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /// Wraps `NetworkContext` and the blockchain client
 | /// Wraps `NetworkContext` and the blockchain client
 | ||||||
|  | |||||||
| @ -173,7 +173,7 @@ impl NetworkProtocolHandler<SyncMessage> for EthSync { | |||||||
| 			SyncMessage::NewChainHead => { | 			SyncMessage::NewChainHead => { | ||||||
| 				let mut sync_io = NetSyncIo::new(io, self.chain.deref()); | 				let mut sync_io = NetSyncIo::new(io, self.chain.deref()); | ||||||
| 				self.sync.write().unwrap().chain_new_head(&mut sync_io); | 				self.sync.write().unwrap().chain_new_head(&mut sync_io); | ||||||
| 			} | 			}, | ||||||
| 			_ => {/* Ignore other messages */}, | 			_ => {/* Ignore other messages */}, | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -27,9 +27,8 @@ crossbeam = "0.2" | |||||||
| slab = "0.1" | slab = "0.1" | ||||||
| sha3 = { path = "sha3" } | sha3 = { path = "sha3" } | ||||||
| serde = "0.7.0" | serde = "0.7.0" | ||||||
| clippy = { version = "0.0.50", optional = true } | clippy = { version = "0.0.54", optional = true } | ||||||
| json-tests = { path = "json-tests" } | json-tests = { path = "json-tests" } | ||||||
| rustc_version = "0.1.0" |  | ||||||
| igd = "0.4.2" | igd = "0.4.2" | ||||||
| ethcore-devtools = { path = "../devtools" } | ethcore-devtools = { path = "../devtools" } | ||||||
| libc = "0.2.7" | libc = "0.2.7" | ||||||
| @ -44,3 +43,4 @@ dev = ["clippy"] | |||||||
| 
 | 
 | ||||||
| [build-dependencies] | [build-dependencies] | ||||||
| vergen = "*" | vergen = "*" | ||||||
|  | rustc_version = "0.1.0" | ||||||
|  | |||||||
| @ -15,9 +15,23 @@ | |||||||
| // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
| 
 | 
 | ||||||
| extern crate vergen; | extern crate vergen; | ||||||
|  | extern crate rustc_version; | ||||||
| 
 | 
 | ||||||
| use vergen::*; | use vergen::*; | ||||||
|  | use std::env; | ||||||
|  | use std::fs::File; | ||||||
|  | use std::io::Write; | ||||||
|  | use std::path::Path; | ||||||
| 
 | 
 | ||||||
| fn main() { | fn main() { | ||||||
| 	vergen(OutputFns::all()).unwrap(); | 	vergen(OutputFns::all()).unwrap(); | ||||||
|  | 	let out_dir = env::var("OUT_DIR").unwrap(); | ||||||
|  | 	let dest_path = Path::new(&out_dir).join("rustc_version.rs"); | ||||||
|  | 	let mut f = File::create(&dest_path).unwrap(); | ||||||
|  | 	f.write_all(format!(" | ||||||
|  | 		/// Returns compiler version.
 | ||||||
|  | 		pub fn rustc_version() -> &'static str {{ | ||||||
|  | 			\"{}\" | ||||||
|  | 		}} | ||||||
|  | 	", rustc_version::version()).as_bytes()).unwrap();
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -175,6 +175,8 @@ impl JournalDB for ArchiveDB { | |||||||
| 
 | 
 | ||||||
| #[cfg(test)] | #[cfg(test)] | ||||||
| mod tests { | mod tests { | ||||||
|  | 	#![cfg_attr(feature="dev", allow(blacklisted_name))] | ||||||
|  | 
 | ||||||
| 	use common::*; | 	use common::*; | ||||||
| 	use super::*; | 	use super::*; | ||||||
| 	use hashdb::*; | 	use hashdb::*; | ||||||
|  | |||||||
| @ -527,6 +527,8 @@ impl JournalDB for EarlyMergeDB { | |||||||
| 
 | 
 | ||||||
| #[cfg(test)] | #[cfg(test)] | ||||||
| mod tests { | mod tests { | ||||||
|  | 	#![cfg_attr(feature="dev", allow(blacklisted_name))] | ||||||
|  | 
 | ||||||
| 	use common::*; | 	use common::*; | ||||||
| 	use super::*; | 	use super::*; | ||||||
| 	use super::super::traits::JournalDB; | 	use super::super::traits::JournalDB; | ||||||
|  | |||||||
| @ -358,6 +358,8 @@ impl HashDB for OverlayRecentDB { | |||||||
| 
 | 
 | ||||||
| #[cfg(test)] | #[cfg(test)] | ||||||
| mod tests { | mod tests { | ||||||
|  | 	#![cfg_attr(feature="dev", allow(blacklisted_name))] | ||||||
|  | 
 | ||||||
| 	use common::*; | 	use common::*; | ||||||
| 	use super::*; | 	use super::*; | ||||||
| 	use hashdb::*; | 	use hashdb::*; | ||||||
|  | |||||||
| @ -194,6 +194,8 @@ impl JournalDB for RefCountedDB { | |||||||
| 
 | 
 | ||||||
| #[cfg(test)] | #[cfg(test)] | ||||||
| mod tests { | mod tests { | ||||||
|  | 	#![cfg_attr(feature="dev", allow(blacklisted_name))] | ||||||
|  | 
 | ||||||
| 	use common::*; | 	use common::*; | ||||||
| 	use super::*; | 	use super::*; | ||||||
| 	use super::super::traits::JournalDB; | 	use super::super::traits::JournalDB; | ||||||
|  | |||||||
| @ -109,9 +109,7 @@ extern crate log as rlog; | |||||||
| extern crate igd; | extern crate igd; | ||||||
| extern crate ethcore_devtools as devtools; | extern crate ethcore_devtools as devtools; | ||||||
| extern crate libc; | extern crate libc; | ||||||
| extern crate rustc_version; |  | ||||||
| extern crate target_info; | extern crate target_info; | ||||||
| extern crate vergen; |  | ||||||
| extern crate bigint; | extern crate bigint; | ||||||
| extern crate chrono; | extern crate chrono; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -20,9 +20,9 @@ use std::fs::File; | |||||||
| use common::*; | use common::*; | ||||||
| use rlp::{Stream, RlpStream}; | use rlp::{Stream, RlpStream}; | ||||||
| use target_info::Target; | use target_info::Target; | ||||||
| use rustc_version; |  | ||||||
| 
 | 
 | ||||||
| include!(concat!(env!("OUT_DIR"), "/version.rs")); | include!(concat!(env!("OUT_DIR"), "/version.rs")); | ||||||
|  | include!(concat!(env!("OUT_DIR"), "/rustc_version.rs")); | ||||||
| 
 | 
 | ||||||
| #[derive(Debug,Clone,PartialEq,Eq)] | #[derive(Debug,Clone,PartialEq,Eq)] | ||||||
| /// Diff type for specifying a change (or not).
 | /// Diff type for specifying a change (or not).
 | ||||||
| @ -70,7 +70,13 @@ pub fn contents(name: &str) -> Result<Bytes, UtilError> { | |||||||
| 
 | 
 | ||||||
| /// Get the standard version string for this software.
 | /// Get the standard version string for this software.
 | ||||||
| pub fn version() -> String { | pub fn version() -> String { | ||||||
| 	format!("Parity/v{}-unstable-{}-{}/{}-{}-{}/rustc{}", env!("CARGO_PKG_VERSION"), short_sha(), commit_date().replace("-", ""), Target::arch(), Target::os(), Target::env(), rustc_version::version()) | 	let sha3 = short_sha(); | ||||||
|  | 	let sha3_dash = if sha3.is_empty() { "" } else { "-" }; | ||||||
|  | 	let commit_date = commit_date().replace("-", ""); | ||||||
|  | 	let date_dash = if commit_date.is_empty() { "" } else { "-" }; | ||||||
|  | 	let env = Target::env(); | ||||||
|  | 	let env_dash = if env.is_empty() { "" } else { "-" }; | ||||||
|  | 	format!("Parity/v{}-unstable{}{}{}{}/{}-{}{}{}/rustc{}", env!("CARGO_PKG_VERSION"), sha3_dash, sha3, date_dash, commit_date, Target::arch(), Target::os(), env_dash, env, rustc_version()) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /// Get the standard version data for this software.
 | /// Get the standard version data for this software.
 | ||||||
| @ -82,7 +88,7 @@ pub fn version_data() -> Bytes { | |||||||
| 		u32::from_str(env!("CARGO_PKG_VERSION_PATCH")).unwrap(); | 		u32::from_str(env!("CARGO_PKG_VERSION_PATCH")).unwrap(); | ||||||
| 	s.append(&v); | 	s.append(&v); | ||||||
| 	s.append(&"Parity"); | 	s.append(&"Parity"); | ||||||
| 	s.append(&format!("{}", rustc_version::version())); | 	s.append(&rustc_version()); | ||||||
| 	s.append(&&Target::os()[0..2]); | 	s.append(&&Target::os()[0..2]); | ||||||
| 	s.out() | 	s.out() | ||||||
| } | } | ||||||
|  | |||||||
| @ -216,6 +216,8 @@ fn can_map_external_address_or_fail() { | |||||||
| 
 | 
 | ||||||
| #[test] | #[test] | ||||||
| fn ipv4_properties() { | fn ipv4_properties() { | ||||||
|  | 
 | ||||||
|  | 	#![cfg_attr(feature="dev", allow(too_many_arguments))] | ||||||
| 	fn check(octets: &[u8; 4], unspec: bool, loopback: bool, | 	fn check(octets: &[u8; 4], unspec: bool, loopback: bool, | ||||||
| 			 private: bool, link_local: bool, global: bool, | 			 private: bool, link_local: bool, global: bool, | ||||||
| 			 multicast: bool, broadcast: bool, documentation: bool) { | 			 multicast: bool, broadcast: bool, documentation: bool) { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user