Skip to content
This repository has been archived by the owner on Nov 6, 2020. It is now read-only.

Authority round consensus engine #3426

Merged
merged 96 commits into from
Nov 16, 2016
Merged
Changes from 1 commit
Commits
Show all changes
96 commits
Select commit Hold shift + click to select a range
c31eab5
add non renewing timer
Sep 1, 2016
3a68fab
new simple authority engine
Sep 8, 2016
747898d
add new engine to spec
Sep 8, 2016
fc3d01e
add tests, fixes, simplifications
Sep 8, 2016
965dde8
enable TestNet with custom spec
Sep 9, 2016
4e75686
separate block preparation methods
Sep 10, 2016
cadca64
Split internal sealing from work sealing, add cli option
Sep 11, 2016
c0201bd
replace cli with engine method, simplify
Sep 12, 2016
d6e5637
Merge branch 'master' into split-internal-seal
Sep 12, 2016
d98f69c
Merge remote-tracking branch 'parity/split-internal-seal' into auth-r…
Sep 12, 2016
4bfdeea
More docs about sealing types. Bypass work in external txs.
Sep 12, 2016
1e20716
Merge remote-tracking branch 'parity/split-internal-seal' into auth-r…
Sep 12, 2016
e41b6c4
split requires_reseal, add test and new test miner
Sep 13, 2016
8b9e7c0
Merge remote-tracking branch 'parity/split-internal-seal' into auth-r…
Sep 13, 2016
6760132
make test helpers not test, add some docs
Sep 13, 2016
6a33f8b
state constructor used only in tests
Sep 13, 2016
eee6be1
implement new predicate trait
Sep 13, 2016
da2f117
new test_net holding Client
Sep 13, 2016
0994681
Merge remote-tracking branch 'parity/master' into auth-round
Sep 13, 2016
bdba423
Merge remote-tracking branch 'parity/master'
Sep 13, 2016
fef9420
enable internal sealing based on author
Sep 13, 2016
2bd8226
add tests, keep track of engine sealing status
Sep 13, 2016
0880d4a
method to check if default address is_sealer
Sep 14, 2016
7f05021
Merge remote-tracking branch 'parity/should-seal' into auth-round
Sep 14, 2016
ddb6fec
add new test specs
Sep 14, 2016
bedbe6e
update test spec loading
Sep 14, 2016
28a088e
add client own_tx import through client
Sep 14, 2016
7eac946
remove unused original TestNet method
Sep 14, 2016
faa9c7f
add new TestNet transaction issuing
Sep 14, 2016
b2c0a9d
introduce ethkey dependency to generate txs
Sep 14, 2016
68fd862
simplify constructors
Sep 14, 2016
c6c951d
Merge remote-tracking branch 'parity/should-seal' into auth-round
Sep 14, 2016
7c82a10
fix typo
Sep 14, 2016
a44e2b0
Merge remote-tracking branch 'parity/should-seal' into auth-round
Sep 14, 2016
c482b8f
enable sealing only is authority
Sep 14, 2016
bb59c22
docs on authority spec
Sep 14, 2016
d3ec858
new constructor that takes AccountProvider
Sep 14, 2016
44fe864
new highway to miner, set_author
Sep 14, 2016
3419549
revamp dummy_client to take accounts
Sep 14, 2016
b144bd2
add tracing
Sep 19, 2016
b31e732
temporary is_sealer check disable
Sep 19, 2016
c6c45db
add devtools dependency
Sep 19, 2016
6af888f
disable TemporaryPath panic
Sep 19, 2016
fdcda41
add tracing
Sep 19, 2016
49b8e14
initial mocknet with chain notify
Sep 19, 2016
ce3e875
additional consensus test
Sep 19, 2016
551b5d7
Merge remote-tracking branch 'parity/master'
Sep 19, 2016
49fba0b
Merge branch 'master' into auth-round
Sep 19, 2016
7f177f2
revert dummy_client changes
Sep 19, 2016
d84f949
add proposer step to seal
Sep 19, 2016
44c4845
fix up step switching test
Sep 19, 2016
9d23915
more simulation methods
Sep 20, 2016
c57e3ce
sync check method
Sep 21, 2016
ec058cd
reseal on timeout
Sep 27, 2016
cf88641
more mocknet tests
Sep 27, 2016
5fac941
Merge remote-tracking branch 'parity/master'
Sep 27, 2016
0c69d4a
Merge remote-tracking branch 'parity/master' into auth-round
Sep 27, 2016
28cf91c
remove mocknet stuff, clean up debug
Sep 27, 2016
1c801c9
revert random path drop panic
Sep 27, 2016
7e1d714
block time in decimal
Sep 27, 2016
44f42ac
Merge remote-tracking branch 'parity/master' into auth-round-no-mocknet
Oct 12, 2016
303f922
steps based on unix epoch
Oct 15, 2016
aa05823
Merge remote-tracking branch 'parity/master' into auth-round-no-mocknet
Oct 24, 2016
4ee669b
Merge remote-tracking branch 'parity/master'
Oct 26, 2016
3ff26dd
Merge branch 'master' into auth-round-no-mocknet
Oct 26, 2016
63cc5c0
Merge remote-tracking branch 'parity/master'
Oct 28, 2016
7976f46
Merge branch 'master' into auth-round-no-mocknet
Oct 28, 2016
37ca1fa
Merge remote-tracking branch 'parity/master'
Oct 30, 2016
fc4664a
Merge branch 'master' into auth-round-no-mocknet
Oct 30, 2016
a33e2f2
fix deadlock after merge
Nov 1, 2016
3a6b56e
check double signing, tracing
Nov 1, 2016
da32531
ignore block timeout when sealing internally
Nov 2, 2016
26155f5
proper calculation of remaining step time
Nov 2, 2016
03c9760
Merge remote-tracking branch 'parity/master' into auth-round-no-mocknet
Nov 2, 2016
b2a3851
Merge remote-tracking branch 'auth/auth-round-no-mocknet' into auth-r…
Nov 2, 2016
00a3619
header methods
Nov 2, 2016
045a65c
Merge remote-tracking branch 'auth/auth-round-no-mocknet' into auth-r…
Nov 2, 2016
12125dc
Merge branch 'master' into auth-round
Nov 3, 2016
255ec0c
Merge branch 'master' into auth-round
Nov 4, 2016
9de910c
Merge branch 'master' into auth-round
Nov 4, 2016
0e5060d
update schedule
Nov 4, 2016
a8b688b
allow permanent unlock for internal sealing
Nov 4, 2016
49f2a72
Merge branch 'master' into auth-round
Nov 9, 2016
501f6d3
Merge branch 'master' into auth-round
Nov 14, 2016
b5c8918
fix merge
Nov 14, 2016
165e2be
modify proposer test
Nov 14, 2016
8a86c11
enable force sealing
Nov 14, 2016
8be8b3e
ensure no double proposals
Nov 14, 2016
5de7d50
add test for multi proposals
Nov 14, 2016
1e3ae9f
typos, header functions
Nov 14, 2016
06ebd5f
remove most panics
Nov 14, 2016
ae5ae76
Merge branch 'master' into auth-round
Nov 14, 2016
9d46401
revert to try!
Nov 14, 2016
071e66c
fix flaky test
Nov 14, 2016
fde6ff2
nicer extra info
Nov 15, 2016
8efaf08
typos and warning
Nov 15, 2016
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
make test helpers not test, add some docs
keorn committed Sep 13, 2016

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature.
commit 67601327afc04bcfcbb585213765409ca38fd3d2
5 changes: 3 additions & 2 deletions ethcore/src/lib.rs
Original file line number Diff line number Diff line change
@@ -152,8 +152,9 @@ mod blockchain;
mod types;
mod factory;

#[cfg(test)]
mod tests;
//#[cfg(test)]
#[allow(missing_docs)]
pub mod tests;
#[cfg(test)]
#[cfg(feature="json-tests")]
mod json_tests;
20 changes: 19 additions & 1 deletion ethcore/src/tests/helpers.rs
Original file line number Diff line number Diff line change
@@ -36,6 +36,7 @@ pub enum ChainEra {
DaoHardfork,
}

/// Engine for testing nested calls.
pub struct TestEngine {
engine: Arc<Engine>,
max_depth: usize
@@ -124,7 +125,12 @@ pub fn create_test_block_with_data(header: &Header, transactions: &[SignedTransa
}

pub fn generate_dummy_client(block_number: u32) -> GuardedTempResult<Arc<Client>> {
generate_dummy_client_with_spec_and_data(Spec::new_test, block_number, 0, &[])
generate_dummy_client_with_spec(Spec::new_test, block_number)
}

pub fn generate_dummy_client_with_spec<F>(get_spec: F, block_number: u32) -> GuardedTempResult<Arc<Client>> where
F: Fn()->Spec {
generate_dummy_client_with_spec_and_data(get_spec, block_number, 0, &[])
}

pub fn generate_dummy_client_with_data(block_number: u32, txs_per_block: usize, tx_gas_prices: &[U256]) -> GuardedTempResult<Arc<Client>> {
@@ -266,13 +272,15 @@ pub fn get_test_client_with_blocks(blocks: Vec<Bytes>) -> GuardedTempResult<Arc<
}
}

/// New db at path.
fn new_db(path: &str) -> Arc<Database> {
Arc::new(
Database::open(&DatabaseConfig::with_columns(::db::NUM_COLUMNS), path)
.expect("Opening database for tests should always work.")
)
}

/// Make blockchain.
pub fn generate_dummy_blockchain(block_number: u32) -> GuardedTempResult<BlockChain> {
let temp = RandomTempPath::new();
let db = new_db(temp.as_str());
@@ -291,6 +299,7 @@ pub fn generate_dummy_blockchain(block_number: u32) -> GuardedTempResult<BlockCh
}
}

/// Blockchain with extra data.
pub fn generate_dummy_blockchain_with_extra(block_number: u32) -> GuardedTempResult<BlockChain> {
let temp = RandomTempPath::new();
let db = new_db(temp.as_str());
@@ -310,6 +319,7 @@ pub fn generate_dummy_blockchain_with_extra(block_number: u32) -> GuardedTempRes
}
}

/// Make blochchain.
pub fn generate_dummy_empty_blockchain() -> GuardedTempResult<BlockChain> {
let temp = RandomTempPath::new();
let db = new_db(temp.as_str());
@@ -321,6 +331,7 @@ pub fn generate_dummy_empty_blockchain() -> GuardedTempResult<BlockChain> {
}
}

/// Temporary journal db at random path.
pub fn get_temp_journal_db() -> GuardedTempResult<Box<JournalDB>> {
let temp = RandomTempPath::new();
let journal_db = get_temp_journal_db_in(temp.as_path());
@@ -331,6 +342,7 @@ pub fn get_temp_journal_db() -> GuardedTempResult<Box<JournalDB>> {
}
}

/// Temporary state.
pub fn get_temp_state() -> GuardedTempResult<State> {
let temp = RandomTempPath::new();
let journal_db = get_temp_journal_db_in(temp.as_path());
@@ -341,21 +353,25 @@ pub fn get_temp_state() -> GuardedTempResult<State> {
}
}

/// Temporary journal db.
pub fn get_temp_journal_db_in(path: &Path) -> Box<JournalDB> {
let db = new_db(path.to_str().expect("Only valid utf8 paths for tests."));
journaldb::new(db.clone(), journaldb::Algorithm::EarlyMerge, None)
}

/// Temporary state db.
pub fn get_temp_state_in(path: &Path) -> State {
let journal_db = get_temp_journal_db_in(path);
State::new(journal_db, U256::from(0), Default::default())
}

/// Sequence of good blocks.
pub fn get_good_dummy_block_seq(count: usize) -> Vec<Bytes> {
let test_spec = get_test_spec();
get_good_dummy_block_fork_seq(1, count, &test_spec.genesis_header().hash())
}

/// Forked sequence of good blocks.
pub fn get_good_dummy_block_fork_seq(start_number: usize, count: usize, parent_hash: &H256) -> Vec<Bytes> {
let test_spec = get_test_spec();
let test_engine = &test_spec.engine;
@@ -380,6 +396,7 @@ pub fn get_good_dummy_block_fork_seq(start_number: usize, count: usize, parent_h
r
}

/// Good block.
pub fn get_good_dummy_block() -> Bytes {
let mut block_header = Header::new();
let test_spec = get_test_spec();
@@ -394,6 +411,7 @@ pub fn get_good_dummy_block() -> Bytes {
create_test_block(&block_header)
}

/// Block with bad state.
pub fn get_bad_state_dummy_block() -> Bytes {
let mut block_header = Header::new();
let test_spec = get_test_spec();
2 changes: 2 additions & 0 deletions ethcore/src/tests/mod.rs
Original file line number Diff line number Diff line change
@@ -15,5 +15,7 @@
// along with Parity. If not, see <http://www.gnu.org/licenses/>.

pub mod helpers;
#[cfg(test)]
mod client;
#[cfg(test)]
mod rpc;