We only want to run chain validation in some scenarios (#842)

This commit is contained in:
Antioch Peverell 2018-03-22 18:44:32 -04:00 committed by Ignotus Peverell
parent 3dd627384a
commit 155bab93a4

View file

@ -393,8 +393,11 @@ impl NetToChainAdapter {
let prev_hash = b.header.previous; let prev_hash = b.header.previous;
let bhash = b.hash(); let bhash = b.hash();
let chain = w(&self.chain); let chain = w(&self.chain);
let result = match chain.process_block(b, self.chain_opts()) { match chain.process_block(b, self.chain_opts()) {
Ok(_) => true, Ok(_) => {
self.validate_chain(bhash);
true
}
Err(chain::Error::Orphan) => { Err(chain::Error::Orphan) => {
// make sure we did not miss the parent block // make sure we did not miss the parent block
if !chain.is_orphan(&prev_hash) && !self.currently_syncing.load(Ordering::Relaxed) { if !chain.is_orphan(&prev_hash) && !self.currently_syncing.load(Ordering::Relaxed) {
@ -411,6 +414,11 @@ impl NetToChainAdapter {
"adapter: process_block: {} is a bad block, resetting head", bhash "adapter: process_block: {} is a bad block, resetting head", bhash
); );
let _ = chain.reset_head(); let _ = chain.reset_head();
// we potentially changed the state of the system here
// so check everything is still ok
self.validate_chain(bhash);
false false
} }
Err(e) => { Err(e) => {
@ -420,8 +428,10 @@ impl NetToChainAdapter {
); );
true true
} }
}; }
}
fn validate_chain(&self, bhash: Hash) {
// If we are running in "validate the full chain every block" then // If we are running in "validate the full chain every block" then
// panic here if validation fails for any reason. // panic here if validation fails for any reason.
// We are out of consensus at this point and want to track the problem // We are out of consensus at this point and want to track the problem
@ -448,8 +458,6 @@ impl NetToChainAdapter {
now.elapsed().as_secs(), now.elapsed().as_secs(),
); );
} }
result
} }
// After receiving a compact block if we cannot successfully hydrate // After receiving a compact block if we cannot successfully hydrate