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

Commit c3e551a

Browse files
committed
Be more graceful on Aura difficulty validation (#9164)
* Be more graceful on Aura difficulty validation * test: rejects_step_backwards * test: proposer_switching * test: rejects_future_block * test: reports_skipped * test: verify_empty_seal_steps
1 parent 67a63bb commit c3e551a

File tree

1 file changed

+32
-14
lines changed
  • ethcore/src/engines/authority_round

1 file changed

+32
-14
lines changed

ethcore/src/engines/authority_round/mod.rs

+32-14
Original file line numberDiff line numberDiff line change
@@ -1149,9 +1149,10 @@ impl Engine<EthereumMachine> for AuthorityRound {
11491149

11501150
// If empty step messages are enabled we will validate the messages in the seal, missing messages are not
11511151
// reported as there's no way to tell whether the empty step message was never sent or simply not included.
1152-
if header.number() >= self.empty_steps_transition {
1153-
let validate_empty_steps = || -> Result<(), Error> {
1152+
let empty_steps_len = if header.number() >= self.empty_steps_transition {
1153+
let validate_empty_steps = || -> Result<usize, Error> {
11541154
let empty_steps = header_empty_steps(header)?;
1155+
let empty_steps_len = empty_steps.len();
11551156
for empty_step in empty_steps {
11561157
if empty_step.step <= parent_step || empty_step.step >= step {
11571158
Err(EngineError::InsufficientProof(
@@ -1168,16 +1169,27 @@ impl Engine<EthereumMachine> for AuthorityRound {
11681169
format!("invalid empty step proof: {:?}", empty_step)))?;
11691170
}
11701171
}
1171-
Ok(())
1172+
Ok(empty_steps_len)
11721173
};
11731174

1174-
if let err @ Err(_) = validate_empty_steps() {
1175-
self.validators.report_benign(header.author(), set_number, header.number());
1176-
return err;
1175+
match validate_empty_steps() {
1176+
Ok(len) => len,
1177+
Err(err) => {
1178+
self.validators.report_benign(header.author(), set_number, header.number());
1179+
return Err(err);
1180+
},
11771181
}
1178-
11791182
} else {
11801183
self.report_skipped(header, step, parent_step, &*validators, set_number);
1184+
1185+
0
1186+
};
1187+
1188+
if header.number() >= self.validate_score_transition {
1189+
let expected_difficulty = calculate_score(parent_step.into(), step.into(), empty_steps_len.into());
1190+
if header.difficulty() != &expected_difficulty {
1191+
return Err(From::from(BlockError::InvalidDifficulty(Mismatch { expected: expected_difficulty, found: header.difficulty().clone() })));
1192+
}
11811193
}
11821194

11831195
Ok(())
@@ -1412,7 +1424,7 @@ mod tests {
14121424
use engines::{Seal, Engine, EngineError, EthEngine};
14131425
use engines::validator_set::TestSet;
14141426
use error::{Error, ErrorKind};
1415-
use super::{AuthorityRoundParams, AuthorityRound, EmptyStep, SealedEmptyStep};
1427+
use super::{AuthorityRoundParams, AuthorityRound, EmptyStep, SealedEmptyStep, calculate_score};
14161428

14171429
#[test]
14181430
fn has_valid_metadata() {
@@ -1518,12 +1530,15 @@ mod tests {
15181530

15191531
let engine = Spec::new_test_round().engine;
15201532

1521-
let signature = tap.sign(addr, Some("0".into()), header.bare_hash()).unwrap();
15221533
// Two validators.
15231534
// Spec starts with step 2.
1535+
header.set_difficulty(calculate_score(U256::from(0), U256::from(2), U256::zero()));
1536+
let signature = tap.sign(addr, Some("0".into()), header.bare_hash()).unwrap();
15241537
header.set_seal(vec![encode(&2usize).into_vec(), encode(&(&*signature as &[u8])).into_vec()]);
15251538
assert!(engine.verify_block_family(&header, &parent_header).is_ok());
15261539
assert!(engine.verify_block_external(&header).is_err());
1540+
header.set_difficulty(calculate_score(U256::from(0), U256::from(1), U256::zero()));
1541+
let signature = tap.sign(addr, Some("0".into()), header.bare_hash()).unwrap();
15271542
header.set_seal(vec![encode(&1usize).into_vec(), encode(&(&*signature as &[u8])).into_vec()]);
15281543
assert!(engine.verify_block_family(&header, &parent_header).is_ok());
15291544
assert!(engine.verify_block_external(&header).is_ok());
@@ -1544,9 +1559,10 @@ mod tests {
15441559

15451560
let engine = Spec::new_test_round().engine;
15461561

1547-
let signature = tap.sign(addr, Some("0".into()), header.bare_hash()).unwrap();
15481562
// Two validators.
15491563
// Spec starts with step 2.
1564+
header.set_difficulty(calculate_score(U256::from(0), U256::from(1), U256::zero()));
1565+
let signature = tap.sign(addr, Some("0".into()), header.bare_hash()).unwrap();
15501566
header.set_seal(vec![encode(&1usize).into_vec(), encode(&(&*signature as &[u8])).into_vec()]);
15511567
assert!(engine.verify_block_family(&header, &parent_header).is_ok());
15521568
assert!(engine.verify_block_external(&header).is_ok());
@@ -1573,8 +1589,10 @@ mod tests {
15731589
// Two validators.
15741590
// Spec starts with step 2.
15751591
header.set_seal(vec![encode(&5usize).into_vec(), encode(&(&*signature as &[u8])).into_vec()]);
1592+
header.set_difficulty(calculate_score(U256::from(4), U256::from(5), U256::zero()));
15761593
assert!(engine.verify_block_family(&header, &parent_header).is_ok());
15771594
header.set_seal(vec![encode(&3usize).into_vec(), encode(&(&*signature as &[u8])).into_vec()]);
1595+
header.set_difficulty(calculate_score(U256::from(4), U256::from(3), U256::zero()));
15781596
assert!(engine.verify_block_family(&header, &parent_header).is_err());
15791597
}
15801598

@@ -1608,6 +1626,7 @@ mod tests {
16081626
parent_header.set_seal(vec![encode(&1usize).into_vec()]);
16091627
parent_header.set_gas_limit("222222".parse::<U256>().unwrap());
16101628
let mut header: Header = Header::default();
1629+
header.set_difficulty(calculate_score(U256::from(1), U256::from(3), U256::zero()));
16111630
header.set_gas_limit("222222".parse::<U256>().unwrap());
16121631
header.set_seal(vec![encode(&3usize).into_vec()]);
16131632

@@ -1967,16 +1986,15 @@ mod tests {
19671986
let empty_step3 = sealed_empty_step(engine, 3, &parent_header.hash());
19681987

19691988
let empty_steps = vec![empty_step2, empty_step3];
1989+
header.set_difficulty(calculate_score(U256::from(0), U256::from(4), U256::from(2)));
1990+
let signature = tap.sign(addr1, Some("1".into()), header.bare_hash()).unwrap();
19701991
header.set_seal(vec![
19711992
encode(&4usize).into_vec(),
19721993
encode(&(&*signature as &[u8])).into_vec(),
19731994
::rlp::encode_list(&empty_steps).into_vec(),
19741995
]);
19751996

1976-
assert!(match engine.verify_block_family(&header, &parent_header) {
1977-
Ok(_) => true,
1978-
_ => false,
1979-
});
1997+
assert!(engine.verify_block_family(&header, &parent_header).is_ok());
19801998
}
19811999

19822000
#[test]

0 commit comments

Comments
 (0)