From 1dc957e3a55e14a02963554a9cca047d3a4af0e8 Mon Sep 17 00:00:00 2001 From: Robert Habermeier Date: Fri, 3 Feb 2017 16:11:09 +0100 Subject: [PATCH] allow genesis block to be latest --- ethcore/light/src/client/header_chain.rs | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/ethcore/light/src/client/header_chain.rs b/ethcore/light/src/client/header_chain.rs index 09c69e512..838549656 100644 --- a/ethcore/light/src/client/header_chain.rs +++ b/ethcore/light/src/client/header_chain.rs @@ -214,7 +214,15 @@ impl HeaderChain { .and_then(|hash| self.headers.read().get(&hash).cloned()) } BlockId::Latest | BlockId::Pending => { - let hash = self.best_block.read().hash; + let hash = { + let best = self.best_block.read(); + if best.number == 0 { + return Some(self.genesis_header.clone()) + } + + best.hash + }; + self.headers.read().get(&hash).cloned() } } @@ -380,4 +388,16 @@ mod tests { num -= 1; } } + + #[test] + fn earliest_is_latest() { + let spec = Spec::new_test(); + let genesis_header = spec.genesis_header(); + + let chain = HeaderChain::new(&::rlp::encode(&genesis_header)); + + assert!(chain.get_header(BlockId::Earliest).is_some()); + assert!(chain.get_header(BlockId::Latest).is_some()); + assert!(chain.get_header(BlockId::Pending).is_some()); + } }