* custom dev presets * add registrar field * use constructor for dev registrar * fix test
This commit is contained in:
		
							parent
							
								
									1be865beb0
								
							
						
					
					
						commit
						c585985543
					
				
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -49,6 +49,8 @@ pub struct AuthorityRoundParams { | |||||||
| 	pub step_duration: Duration, | 	pub step_duration: Duration, | ||||||
| 	/// Block reward.
 | 	/// Block reward.
 | ||||||
| 	pub block_reward: U256, | 	pub block_reward: U256, | ||||||
|  | 	/// Namereg contract address.
 | ||||||
|  | 	pub registrar: Address, | ||||||
| 	/// Starting step,
 | 	/// Starting step,
 | ||||||
| 	pub start_step: Option<u64>, | 	pub start_step: Option<u64>, | ||||||
| 	/// Valid validators.
 | 	/// Valid validators.
 | ||||||
| @ -62,6 +64,7 @@ impl From<ethjson::spec::AuthorityRoundParams> for AuthorityRoundParams { | |||||||
| 			step_duration: Duration::from_secs(p.step_duration.into()), | 			step_duration: Duration::from_secs(p.step_duration.into()), | ||||||
| 			validators: p.validators, | 			validators: p.validators, | ||||||
| 			block_reward: p.block_reward.map_or_else(U256::zero, Into::into), | 			block_reward: p.block_reward.map_or_else(U256::zero, Into::into), | ||||||
|  | 			registrar: p.registrar.map_or_else(Address::new, Into::into), | ||||||
| 			start_step: p.start_step.map(Into::into), | 			start_step: p.start_step.map(Into::into), | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| @ -73,6 +76,7 @@ pub struct AuthorityRound { | |||||||
| 	params: CommonParams, | 	params: CommonParams, | ||||||
| 	gas_limit_bound_divisor: U256, | 	gas_limit_bound_divisor: U256, | ||||||
| 	block_reward: U256, | 	block_reward: U256, | ||||||
|  | 	registrar: Address, | ||||||
| 	step_duration: Duration, | 	step_duration: Duration, | ||||||
| 	builtins: BTreeMap<Address, Builtin>, | 	builtins: BTreeMap<Address, Builtin>, | ||||||
| 	transition_service: IoService<()>, | 	transition_service: IoService<()>, | ||||||
| @ -112,6 +116,7 @@ impl AuthorityRound { | |||||||
| 				params: params, | 				params: params, | ||||||
| 				gas_limit_bound_divisor: our_params.gas_limit_bound_divisor, | 				gas_limit_bound_divisor: our_params.gas_limit_bound_divisor, | ||||||
| 				block_reward: our_params.block_reward, | 				block_reward: our_params.block_reward, | ||||||
|  | 				registrar: our_params.registrar, | ||||||
| 				step_duration: our_params.step_duration, | 				step_duration: our_params.step_duration, | ||||||
| 				builtins: builtins, | 				builtins: builtins, | ||||||
| 				transition_service: IoService::<()>::start()?, | 				transition_service: IoService::<()>::start()?, | ||||||
| @ -180,11 +185,16 @@ impl IoHandler<()> for TransitionHandler { | |||||||
| 
 | 
 | ||||||
| impl Engine for AuthorityRound { | impl Engine for AuthorityRound { | ||||||
| 	fn name(&self) -> &str { "AuthorityRound" } | 	fn name(&self) -> &str { "AuthorityRound" } | ||||||
|  | 
 | ||||||
| 	fn version(&self) -> SemanticVersion { SemanticVersion::new(1, 0, 0) } | 	fn version(&self) -> SemanticVersion { SemanticVersion::new(1, 0, 0) } | ||||||
|  | 
 | ||||||
| 	/// Two fields - consensus step and the corresponding proposer signature.
 | 	/// Two fields - consensus step and the corresponding proposer signature.
 | ||||||
| 	fn seal_fields(&self) -> usize { 2 } | 	fn seal_fields(&self) -> usize { 2 } | ||||||
| 
 | 
 | ||||||
| 	fn params(&self) -> &CommonParams { &self.params } | 	fn params(&self) -> &CommonParams { &self.params } | ||||||
|  | 
 | ||||||
|  | 	fn additional_params(&self) -> HashMap<String, String> { hash_map!["registrar".to_owned() => self.registrar.hex()] } | ||||||
|  | 
 | ||||||
| 	fn builtins(&self) -> &BTreeMap<Address, Builtin> { &self.builtins } | 	fn builtins(&self) -> &BTreeMap<Address, Builtin> { &self.builtins } | ||||||
| 
 | 
 | ||||||
| 	fn step(&self) { | 	fn step(&self) { | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ | |||||||
| // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
| 
 | 
 | ||||||
| use std::collections::BTreeMap; | use std::collections::BTreeMap; | ||||||
| use util::Address; | use util::{Address, HashMap}; | ||||||
| use builtin::Builtin; | use builtin::Builtin; | ||||||
| use engines::{Engine, Seal}; | use engines::{Engine, Seal}; | ||||||
| use env_info::EnvInfo; | use env_info::EnvInfo; | ||||||
| @ -26,14 +26,16 @@ use block::ExecutedBlock; | |||||||
| /// An engine which does not provide any consensus mechanism, just seals blocks internally.
 | /// An engine which does not provide any consensus mechanism, just seals blocks internally.
 | ||||||
| pub struct InstantSeal { | pub struct InstantSeal { | ||||||
| 	params: CommonParams, | 	params: CommonParams, | ||||||
|  | 	registrar: Address, | ||||||
| 	builtins: BTreeMap<Address, Builtin>, | 	builtins: BTreeMap<Address, Builtin>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl InstantSeal { | impl InstantSeal { | ||||||
| 	/// Returns new instance of InstantSeal with default VM Factory
 | 	/// Returns new instance of InstantSeal with default VM Factory
 | ||||||
| 	pub fn new(params: CommonParams, builtins: BTreeMap<Address, Builtin>) -> Self { | 	pub fn new(params: CommonParams, registrar: Address, builtins: BTreeMap<Address, Builtin>) -> Self { | ||||||
| 		InstantSeal { | 		InstantSeal { | ||||||
| 			params: params, | 			params: params, | ||||||
|  | 			registrar: registrar, | ||||||
| 			builtins: builtins, | 			builtins: builtins, | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| @ -48,6 +50,10 @@ impl Engine for InstantSeal { | |||||||
| 		&self.params | 		&self.params | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	fn additional_params(&self) -> HashMap<String, String> { | ||||||
|  | 		hash_map!["registrar".to_owned() => self.registrar.hex()] | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	fn builtins(&self) -> &BTreeMap<Address, Builtin> { | 	fn builtins(&self) -> &BTreeMap<Address, Builtin> { | ||||||
| 		&self.builtins | 		&self.builtins | ||||||
| 	} | 	} | ||||||
| @ -76,9 +82,9 @@ mod tests { | |||||||
| 	fn instant_can_seal() { | 	fn instant_can_seal() { | ||||||
| 		let spec = Spec::new_instant(); | 		let spec = Spec::new_instant(); | ||||||
| 		let engine = &*spec.engine; | 		let engine = &*spec.engine; | ||||||
| 		let genesis_header = spec.genesis_header(); |  | ||||||
| 		let mut db_result = get_temp_state_db(); | 		let mut db_result = get_temp_state_db(); | ||||||
| 		let db = spec.ensure_db_good(db_result.take(), &Default::default()).unwrap(); | 		let db = spec.ensure_db_good(db_result.take(), &Default::default()).unwrap(); | ||||||
|  | 		let genesis_header = spec.genesis_header(); | ||||||
| 		let last_hashes = Arc::new(vec![genesis_header.hash()]); | 		let last_hashes = Arc::new(vec![genesis_header.hash()]); | ||||||
| 		let b = OpenBlock::new(engine, Default::default(), false, db, &genesis_header, last_hashes, Address::default(), (3141562.into(), 31415620.into()), vec![]).unwrap(); | 		let b = OpenBlock::new(engine, Default::default(), false, db, &genesis_header, last_hashes, Address::default(), (3141562.into(), 31415620.into()), vec![]).unwrap(); | ||||||
| 		let b = b.close_and_lock(); | 		let b = b.close_and_lock(); | ||||||
|  | |||||||
| @ -86,6 +86,7 @@ pub struct Tendermint { | |||||||
| 	authority: RwLock<Address>, | 	authority: RwLock<Address>, | ||||||
| 	/// Password used for signing messages.
 | 	/// Password used for signing messages.
 | ||||||
| 	password: RwLock<Option<String>>, | 	password: RwLock<Option<String>>, | ||||||
|  | 	registrar: Address, | ||||||
| 	/// Blockchain height.
 | 	/// Blockchain height.
 | ||||||
| 	height: AtomicUsize, | 	height: AtomicUsize, | ||||||
| 	/// Consensus round.
 | 	/// Consensus round.
 | ||||||
| @ -119,6 +120,7 @@ impl Tendermint { | |||||||
| 				block_reward: our_params.block_reward, | 				block_reward: our_params.block_reward, | ||||||
| 				authority: RwLock::new(Address::default()), | 				authority: RwLock::new(Address::default()), | ||||||
| 				password: RwLock::new(None), | 				password: RwLock::new(None), | ||||||
|  | 				registrar: our_params.registrar, | ||||||
| 				height: AtomicUsize::new(1), | 				height: AtomicUsize::new(1), | ||||||
| 				round: AtomicUsize::new(0), | 				round: AtomicUsize::new(0), | ||||||
| 				step: RwLock::new(Step::Propose), | 				step: RwLock::new(Step::Propose), | ||||||
| @ -376,14 +378,20 @@ impl Tendermint { | |||||||
| 
 | 
 | ||||||
| impl Engine for Tendermint { | impl Engine for Tendermint { | ||||||
| 	fn name(&self) -> &str { "Tendermint" } | 	fn name(&self) -> &str { "Tendermint" } | ||||||
|  | 
 | ||||||
| 	fn version(&self) -> SemanticVersion { SemanticVersion::new(1, 0, 0) } | 	fn version(&self) -> SemanticVersion { SemanticVersion::new(1, 0, 0) } | ||||||
|  | 
 | ||||||
| 	/// (consensus round, proposal signature, authority signatures)
 | 	/// (consensus round, proposal signature, authority signatures)
 | ||||||
| 	fn seal_fields(&self) -> usize { 3 } | 	fn seal_fields(&self) -> usize { 3 } | ||||||
| 
 | 
 | ||||||
| 	fn params(&self) -> &CommonParams { &self.params } | 	fn params(&self) -> &CommonParams { &self.params } | ||||||
|  | 
 | ||||||
|  | 	fn additional_params(&self) -> HashMap<String, String> { hash_map!["registrar".to_owned() => self.registrar.hex()] } | ||||||
|  | 
 | ||||||
| 	fn builtins(&self) -> &BTreeMap<Address, Builtin> { &self.builtins } | 	fn builtins(&self) -> &BTreeMap<Address, Builtin> { &self.builtins } | ||||||
| 
 | 
 | ||||||
| 	fn maximum_uncle_count(&self) -> usize { 0 } | 	fn maximum_uncle_count(&self) -> usize { 0 } | ||||||
|  | 
 | ||||||
| 	fn maximum_uncle_age(&self) -> usize { 0 } | 	fn maximum_uncle_age(&self) -> usize { 0 } | ||||||
| 
 | 
 | ||||||
| 	/// Additional engine-specific information for the user/developer concerning `header`.
 | 	/// Additional engine-specific information for the user/developer concerning `header`.
 | ||||||
|  | |||||||
| @ -18,7 +18,7 @@ | |||||||
| 
 | 
 | ||||||
| use ethjson; | use ethjson; | ||||||
| use super::transition::TendermintTimeouts; | use super::transition::TendermintTimeouts; | ||||||
| use util::{U256, Uint}; | use util::{U256, Uint, Address, FixedHash}; | ||||||
| use time::Duration; | use time::Duration; | ||||||
| 
 | 
 | ||||||
| /// `Tendermint` params.
 | /// `Tendermint` params.
 | ||||||
| @ -32,6 +32,8 @@ pub struct TendermintParams { | |||||||
| 	pub timeouts: TendermintTimeouts, | 	pub timeouts: TendermintTimeouts, | ||||||
| 	/// Block reward.
 | 	/// Block reward.
 | ||||||
| 	pub block_reward: U256, | 	pub block_reward: U256, | ||||||
|  | 	/// Namereg contract address.
 | ||||||
|  | 	pub registrar: Address, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn to_duration(ms: ethjson::uint::Uint) -> Duration { | fn to_duration(ms: ethjson::uint::Uint) -> Duration { | ||||||
| @ -52,6 +54,7 @@ impl From<ethjson::spec::TendermintParams> for TendermintParams { | |||||||
| 				commit: p.timeout_commit.map_or(dt.commit, to_duration), | 				commit: p.timeout_commit.map_or(dt.commit, to_duration), | ||||||
| 			}, | 			}, | ||||||
| 			block_reward: p.block_reward.map_or_else(U256::zero, Into::into), | 			block_reward: p.block_reward.map_or_else(U256::zero, Into::into), | ||||||
|  | 			registrar: p.registrar.map_or_else(Address::new, Into::into), | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | |||||||
| @ -157,7 +157,7 @@ impl Spec { | |||||||
| 	fn engine(engine_spec: ethjson::spec::Engine, params: CommonParams, builtins: BTreeMap<Address, Builtin>) -> Arc<Engine> { | 	fn engine(engine_spec: ethjson::spec::Engine, params: CommonParams, builtins: BTreeMap<Address, Builtin>) -> Arc<Engine> { | ||||||
| 		match engine_spec { | 		match engine_spec { | ||||||
| 			ethjson::spec::Engine::Null => Arc::new(NullEngine::new(params, builtins)), | 			ethjson::spec::Engine::Null => Arc::new(NullEngine::new(params, builtins)), | ||||||
| 			ethjson::spec::Engine::InstantSeal => Arc::new(InstantSeal::new(params, builtins)), | 			ethjson::spec::Engine::InstantSeal(instant) => Arc::new(InstantSeal::new(params, instant.params.registrar.map_or_else(Address::new, Into::into), builtins)), | ||||||
| 			ethjson::spec::Engine::Ethash(ethash) => Arc::new(ethereum::Ethash::new(params, From::from(ethash.params), builtins)), | 			ethjson::spec::Engine::Ethash(ethash) => Arc::new(ethereum::Ethash::new(params, From::from(ethash.params), builtins)), | ||||||
| 			ethjson::spec::Engine::BasicAuthority(basic_authority) => Arc::new(BasicAuthority::new(params, From::from(basic_authority.params), builtins)), | 			ethjson::spec::Engine::BasicAuthority(basic_authority) => Arc::new(BasicAuthority::new(params, From::from(basic_authority.params), builtins)), | ||||||
| 			ethjson::spec::Engine::AuthorityRound(authority_round) => AuthorityRound::new(params, From::from(authority_round.params), builtins).expect("Failed to start AuthorityRound consensus engine."), | 			ethjson::spec::Engine::AuthorityRound(authority_round) => AuthorityRound::new(params, From::from(authority_round.params), builtins).expect("Failed to start AuthorityRound consensus engine."), | ||||||
|  | |||||||
| @ -17,6 +17,7 @@ | |||||||
| //! Authority params deserialization.
 | //! Authority params deserialization.
 | ||||||
| 
 | 
 | ||||||
| use uint::Uint; | use uint::Uint; | ||||||
|  | use hash::Address; | ||||||
| use super::ValidatorSet; | use super::ValidatorSet; | ||||||
| 
 | 
 | ||||||
| /// Authority params deserialization.
 | /// Authority params deserialization.
 | ||||||
| @ -33,6 +34,8 @@ pub struct AuthorityRoundParams { | |||||||
| 	/// Block reward.
 | 	/// Block reward.
 | ||||||
| 	#[serde(rename="blockReward")] | 	#[serde(rename="blockReward")] | ||||||
| 	pub block_reward: Option<Uint>, | 	pub block_reward: Option<Uint>, | ||||||
|  | 	/// Address of the registrar contract.
 | ||||||
|  | 	pub registrar: Option<Address>, | ||||||
| 	/// Starting step. Determined automatically if not specified.
 | 	/// Starting step. Determined automatically if not specified.
 | ||||||
| 	/// To be used for testing only.
 | 	/// To be used for testing only.
 | ||||||
| 	#[serde(rename="startStep")] | 	#[serde(rename="startStep")] | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| //! Engine deserialization.
 | //! Engine deserialization.
 | ||||||
| 
 | 
 | ||||||
| use super::{Ethash, BasicAuthority, AuthorityRound, Tendermint}; | use super::{Ethash, InstantSeal, BasicAuthority, AuthorityRound, Tendermint}; | ||||||
| 
 | 
 | ||||||
| /// Engine deserialization.
 | /// Engine deserialization.
 | ||||||
| #[derive(Debug, PartialEq, Deserialize)] | #[derive(Debug, PartialEq, Deserialize)] | ||||||
| @ -26,7 +26,7 @@ pub enum Engine { | |||||||
| 	Null, | 	Null, | ||||||
| 	/// Instantly sealing engine.
 | 	/// Instantly sealing engine.
 | ||||||
| 	#[serde(rename="instantSeal")] | 	#[serde(rename="instantSeal")] | ||||||
| 	InstantSeal, | 	InstantSeal(InstantSeal), | ||||||
| 	/// Ethash engine.
 | 	/// Ethash engine.
 | ||||||
| 	Ethash(Ethash), | 	Ethash(Ethash), | ||||||
| 	/// BasicAuthority engine.
 | 	/// BasicAuthority engine.
 | ||||||
| @ -55,12 +55,10 @@ mod tests { | |||||||
| 		assert_eq!(Engine::Null, deserialized); | 		assert_eq!(Engine::Null, deserialized); | ||||||
| 
 | 
 | ||||||
| 		let s = r#"{
 | 		let s = r#"{
 | ||||||
| 			"instantSeal": null | 			"instantSeal": { "params": {} } | ||||||
| 		}"#;
 | 		}"#;
 | ||||||
| 
 | 
 | ||||||
| 		let deserialized: Engine = serde_json::from_str(s).unwrap(); | 		let _deserialized: Engine = serde_json::from_str(s).unwrap(); | ||||||
| 		assert_eq!(Engine::InstantSeal, deserialized); |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| 		let s = r#"{
 | 		let s = r#"{
 | ||||||
| 			"Ethash": { | 			"Ethash": { | ||||||
|  | |||||||
							
								
								
									
										50
									
								
								json/src/spec/instant_seal.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								json/src/spec/instant_seal.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,50 @@ | |||||||
|  | // Copyright 2015-2017 Parity Technologies (UK) Ltd.
 | ||||||
|  | // This file is part of Parity.
 | ||||||
|  | 
 | ||||||
|  | // Parity 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 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.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | 
 | ||||||
|  | //! Instant params deserialization.
 | ||||||
|  | 
 | ||||||
|  | use hash::Address; | ||||||
|  | 
 | ||||||
|  | /// Instant params deserialization.
 | ||||||
|  | #[derive(Debug, PartialEq, Deserialize)] | ||||||
|  | pub struct InstantSealParams { | ||||||
|  | 	/// Address of the registrar contract.
 | ||||||
|  | 	pub registrar: Option<Address>, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /// Instant engine deserialization.
 | ||||||
|  | #[derive(Debug, PartialEq, Deserialize)] | ||||||
|  | pub struct InstantSeal { | ||||||
|  | 	/// Instant Seal params.
 | ||||||
|  | 	pub params: InstantSealParams, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[cfg(test)] | ||||||
|  | mod tests { | ||||||
|  | 	use serde_json; | ||||||
|  | 	use spec::instant_seal::InstantSeal; | ||||||
|  | 
 | ||||||
|  | 	#[test] | ||||||
|  | 	fn instant_seal_deserialization() { | ||||||
|  | 		let s = r#"{
 | ||||||
|  | 			"params": { | ||||||
|  | 				"registrar": "0xc6d9d2cd449a754c494264e1809c50e34d64562b" | ||||||
|  | 			} | ||||||
|  | 		}"#;
 | ||||||
|  | 
 | ||||||
|  | 		let _deserialized: InstantSeal = serde_json::from_str(s).unwrap(); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @ -26,6 +26,7 @@ pub mod engine; | |||||||
| pub mod state; | pub mod state; | ||||||
| pub mod ethash; | pub mod ethash; | ||||||
| pub mod validator_set; | pub mod validator_set; | ||||||
|  | pub mod instant_seal; | ||||||
| pub mod basic_authority; | pub mod basic_authority; | ||||||
| pub mod authority_round; | pub mod authority_round; | ||||||
| pub mod tendermint; | pub mod tendermint; | ||||||
| @ -40,6 +41,7 @@ pub use self::engine::Engine; | |||||||
| pub use self::state::State; | pub use self::state::State; | ||||||
| pub use self::ethash::{Ethash, EthashParams}; | pub use self::ethash::{Ethash, EthashParams}; | ||||||
| pub use self::validator_set::ValidatorSet; | pub use self::validator_set::ValidatorSet; | ||||||
|  | pub use self::instant_seal::{InstantSeal, InstantSealParams}; | ||||||
| pub use self::basic_authority::{BasicAuthority, BasicAuthorityParams}; | pub use self::basic_authority::{BasicAuthority, BasicAuthorityParams}; | ||||||
| pub use self::authority_round::{AuthorityRound, AuthorityRoundParams}; | pub use self::authority_round::{AuthorityRound, AuthorityRoundParams}; | ||||||
| pub use self::tendermint::{Tendermint, TendermintParams}; | pub use self::tendermint::{Tendermint, TendermintParams}; | ||||||
|  | |||||||
| @ -17,6 +17,7 @@ | |||||||
| //! Tendermint params deserialization.
 | //! Tendermint params deserialization.
 | ||||||
| 
 | 
 | ||||||
| use uint::Uint; | use uint::Uint; | ||||||
|  | use hash::Address; | ||||||
| use super::ValidatorSet; | use super::ValidatorSet; | ||||||
| 
 | 
 | ||||||
| /// Tendermint params deserialization.
 | /// Tendermint params deserialization.
 | ||||||
| @ -42,6 +43,8 @@ pub struct TendermintParams { | |||||||
| 	/// Block reward.
 | 	/// Block reward.
 | ||||||
| 	#[serde(rename="blockReward")] | 	#[serde(rename="blockReward")] | ||||||
| 	pub block_reward: Option<Uint>, | 	pub block_reward: Option<Uint>, | ||||||
|  | 	/// Address of the registrar contract.
 | ||||||
|  | 	pub registrar: Option<Address>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /// Tendermint engine deserialization.
 | /// Tendermint engine deserialization.
 | ||||||
|  | |||||||
| @ -33,7 +33,7 @@ use ethcore_rpc::NetworkSettings; | |||||||
| use cache::CacheConfig; | use cache::CacheConfig; | ||||||
| use helpers::{to_duration, to_mode, to_block_id, to_u256, to_pending_set, to_price, replace_home, replace_home_for_db, | use helpers::{to_duration, to_mode, to_block_id, to_u256, to_pending_set, to_price, replace_home, replace_home_for_db, | ||||||
| geth_ipc_path, parity_ipc_path, to_bootnodes, to_addresses, to_address, to_gas_limit, to_queue_strategy}; | geth_ipc_path, parity_ipc_path, to_bootnodes, to_addresses, to_address, to_gas_limit, to_queue_strategy}; | ||||||
| use params::{ResealPolicy, AccountsConfig, GasPricerConfig, MinerExtras}; | use params::{SpecType, ResealPolicy, AccountsConfig, GasPricerConfig, MinerExtras}; | ||||||
| use ethcore_logger::Config as LogConfig; | use ethcore_logger::Config as LogConfig; | ||||||
| use dir::{self, Directories, default_hypervisor_path, default_local_path, default_data_path}; | use dir::{self, Directories, default_hypervisor_path, default_local_path, default_data_path}; | ||||||
| use dapps::Configuration as DappsConfiguration; | use dapps::Configuration as DappsConfiguration; | ||||||
| @ -102,7 +102,6 @@ impl Configuration { | |||||||
| 		let vm_type = self.vm_type()?; | 		let vm_type = self.vm_type()?; | ||||||
| 		let mode = match self.args.flag_mode.as_ref() { "last" => None, mode => Some(to_mode(&mode, self.args.flag_mode_timeout, self.args.flag_mode_alarm)?), }; | 		let mode = match self.args.flag_mode.as_ref() { "last" => None, mode => Some(to_mode(&mode, self.args.flag_mode_timeout, self.args.flag_mode_alarm)?), }; | ||||||
| 		let update_policy = self.update_policy()?; | 		let update_policy = self.update_policy()?; | ||||||
| 		let miner_options = self.miner_options()?; |  | ||||||
| 		let logger_config = self.logger_config(); | 		let logger_config = self.logger_config(); | ||||||
| 		let http_conf = self.http_config()?; | 		let http_conf = self.http_config()?; | ||||||
| 		let ipc_conf = self.ipc_config()?; | 		let ipc_conf = self.ipc_config()?; | ||||||
| @ -307,6 +306,12 @@ impl Configuration { | |||||||
| 
 | 
 | ||||||
| 			let verifier_settings = self.verifier_settings(); | 			let verifier_settings = self.verifier_settings(); | ||||||
| 
 | 
 | ||||||
|  | 			// Special presets are present for the dev chain.
 | ||||||
|  | 			let (gas_pricer, miner_options) = match spec { | ||||||
|  | 				SpecType::Dev => (GasPricerConfig::Fixed(0.into()), self.miner_options(0)?), | ||||||
|  | 				_ => (self.gas_pricer_config()?, self.miner_options(self.args.flag_reseal_min_period)?), | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
| 			let run_cmd = RunCmd { | 			let run_cmd = RunCmd { | ||||||
| 				cache_config: cache_config, | 				cache_config: cache_config, | ||||||
| 				dirs: dirs, | 				dirs: dirs, | ||||||
| @ -321,7 +326,7 @@ impl Configuration { | |||||||
| 				net_conf: net_conf, | 				net_conf: net_conf, | ||||||
| 				network_id: network_id, | 				network_id: network_id, | ||||||
| 				acc_conf: self.accounts_config()?, | 				acc_conf: self.accounts_config()?, | ||||||
| 				gas_pricer: self.gas_pricer_config()?, | 				gas_pricer: gas_pricer, | ||||||
| 				miner_extras: self.miner_extras()?, | 				miner_extras: self.miner_extras()?, | ||||||
| 				update_policy: update_policy, | 				update_policy: update_policy, | ||||||
| 				mode: mode, | 				mode: mode, | ||||||
| @ -459,7 +464,7 @@ impl Configuration { | |||||||
| 		Ok(cfg) | 		Ok(cfg) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn miner_options(&self) -> Result<MinerOptions, String> { | 	fn miner_options(&self, reseal_min_period: u64) -> Result<MinerOptions, String> { | ||||||
| 		let reseal = self.args.flag_reseal_on_txs.parse::<ResealPolicy>()?; | 		let reseal = self.args.flag_reseal_on_txs.parse::<ResealPolicy>()?; | ||||||
| 
 | 
 | ||||||
| 		let options = MinerOptions { | 		let options = MinerOptions { | ||||||
| @ -475,7 +480,7 @@ impl Configuration { | |||||||
| 			tx_queue_gas_limit: to_gas_limit(&self.args.flag_tx_queue_gas)?, | 			tx_queue_gas_limit: to_gas_limit(&self.args.flag_tx_queue_gas)?, | ||||||
| 			tx_queue_strategy: to_queue_strategy(&self.args.flag_tx_queue_strategy)?, | 			tx_queue_strategy: to_queue_strategy(&self.args.flag_tx_queue_strategy)?, | ||||||
| 			pending_set: to_pending_set(&self.args.flag_relay_set)?, | 			pending_set: to_pending_set(&self.args.flag_relay_set)?, | ||||||
| 			reseal_min_period: Duration::from_millis(self.args.flag_reseal_min_period), | 			reseal_min_period: Duration::from_millis(reseal_min_period), | ||||||
| 			work_queue_size: self.args.flag_work_queue_size, | 			work_queue_size: self.args.flag_work_queue_size, | ||||||
| 			enable_resubmission: !self.args.flag_remove_solved, | 			enable_resubmission: !self.args.flag_remove_solved, | ||||||
| 			tx_queue_banning: match self.args.flag_tx_time_limit { | 			tx_queue_banning: match self.args.flag_tx_time_limit { | ||||||
| @ -1093,13 +1098,14 @@ mod tests { | |||||||
| 		let conf3 = parse(&["parity", "--tx-queue-strategy", "gas"]); | 		let conf3 = parse(&["parity", "--tx-queue-strategy", "gas"]); | ||||||
| 
 | 
 | ||||||
| 		// then
 | 		// then
 | ||||||
| 		assert_eq!(conf0.miner_options().unwrap(), mining_options); | 		let min_period = conf0.args.flag_reseal_min_period; | ||||||
|  | 		assert_eq!(conf0.miner_options(min_period).unwrap(), mining_options); | ||||||
| 		mining_options.tx_queue_strategy = PrioritizationStrategy::GasFactorAndGasPrice; | 		mining_options.tx_queue_strategy = PrioritizationStrategy::GasFactorAndGasPrice; | ||||||
| 		assert_eq!(conf1.miner_options().unwrap(), mining_options); | 		assert_eq!(conf1.miner_options(min_period).unwrap(), mining_options); | ||||||
| 		mining_options.tx_queue_strategy = PrioritizationStrategy::GasPriceOnly; | 		mining_options.tx_queue_strategy = PrioritizationStrategy::GasPriceOnly; | ||||||
| 		assert_eq!(conf2.miner_options().unwrap(), mining_options); | 		assert_eq!(conf2.miner_options(min_period).unwrap(), mining_options); | ||||||
| 		mining_options.tx_queue_strategy = PrioritizationStrategy::GasAndGasPrice; | 		mining_options.tx_queue_strategy = PrioritizationStrategy::GasAndGasPrice; | ||||||
| 		assert_eq!(conf3.miner_options().unwrap(), mining_options); | 		assert_eq!(conf3.miner_options(min_period).unwrap(), mining_options); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	#[test] | 	#[test] | ||||||
| @ -1291,4 +1297,17 @@ mod tests { | |||||||
| 		let conf = Configuration::parse(&args).unwrap(); | 		let conf = Configuration::parse(&args).unwrap(); | ||||||
| 		assert!(conf.init_reserved_nodes().is_ok()); | 		assert!(conf.init_reserved_nodes().is_ok()); | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	#[test] | ||||||
|  | 	fn test_dev_chain() { | ||||||
|  | 		let args = vec!["parity", "--chain", "dev"]; | ||||||
|  | 		let conf = parse(&args); | ||||||
|  | 		match conf.into_command().unwrap().cmd { | ||||||
|  | 			Cmd::Run(c) => { | ||||||
|  | 				assert_eq!(c.gas_pricer, GasPricerConfig::Fixed(0.into())); | ||||||
|  | 				assert_eq!(c.miner_options.reseal_min_period, Duration::from_millis(0)); | ||||||
|  | 			}, | ||||||
|  | 			_ => panic!("Should be Cmd::Run"), | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user