From 995b2715f258b297ba421acf009718c0b6f7447e Mon Sep 17 00:00:00 2001 From: Emilia Hane Date: Sat, 21 Jan 2023 20:54:18 +0100 Subject: [PATCH] Fix network block_lookups test --- .../network/src/beacon_processor/tests.rs | 4 +- .../network/src/sync/block_lookups/tests.rs | 91 ++++++++++++++++--- 2 files changed, 80 insertions(+), 15 deletions(-) diff --git a/beacon_node/network/src/beacon_processor/tests.rs b/beacon_node/network/src/beacon_processor/tests.rs index ea1a59e0d..e2b96fb47 100644 --- a/beacon_node/network/src/beacon_processor/tests.rs +++ b/beacon_node/network/src/beacon_processor/tests.rs @@ -243,7 +243,7 @@ impl TestRig { pub fn enqueue_rpc_block(&self) { let event = WorkEvent::rpc_beacon_block( self.next_block.canonical_root(), - self.next_block.clone(), + self.next_block.clone().into(), std::time::Duration::default(), BlockProcessType::ParentLookup { chain_hash: Hash256::random(), @@ -255,7 +255,7 @@ impl TestRig { pub fn enqueue_single_lookup_rpc_block(&self) { let event = WorkEvent::rpc_beacon_block( self.next_block.canonical_root(), - self.next_block.clone(), + self.next_block.clone().into(), std::time::Duration::default(), BlockProcessType::SingleBlock { id: 1 }, ); diff --git a/beacon_node/network/src/sync/block_lookups/tests.rs b/beacon_node/network/src/sync/block_lookups/tests.rs index f1b966220..48d02b4e7 100644 --- a/beacon_node/network/src/sync/block_lookups/tests.rs +++ b/beacon_node/network/src/sync/block_lookups/tests.rs @@ -4,18 +4,24 @@ use crate::service::RequestId; use crate::sync::manager::RequestId as SyncId; use crate::NetworkMessage; +use sloggers::{null::NullLoggerBuilder, Build}; + use super::*; -use beacon_chain::builder::Witness; -use beacon_chain::eth1_chain::CachingEth1Backend; +use beacon_chain::{ + builder::{BeaconChainBuilder, Witness}, + eth1_chain::CachingEth1Backend, + test_utils::test_spec, +}; use lighthouse_network::{NetworkGlobals, Request}; use slog::{Drain, Level}; -use slot_clock::SystemTimeSlotClock; +use slot_clock::{SlotClock, SystemTimeSlotClock}; +use std::time::{Duration, SystemTime}; use store::MemoryStore; use tokio::sync::mpsc; use types::{ test_utils::{SeedableRng, TestRandom, XorShiftRng}, - MinimalEthSpec as E, SignedBeaconBlock, + EthSpec, MinimalEthSpec as E, SignedBeaconBlock, }; type T = Witness, E, MemoryStore, MemoryStore>; @@ -30,6 +36,29 @@ const D: Duration = Duration::new(0, 0); impl TestRig { fn test_setup(log_level: Option) -> (BlockLookups, SyncNetworkContext, Self) { + let builder = NullLoggerBuilder; + let log = builder.build().expect("should build logger"); + let store = store::HotColdDB::open_ephemeral(store::StoreConfig::default(), E::default_spec(), log).unwrap(); + + // Initialise a new beacon chain from the finalized checkpoint + let chain = BeaconChainBuilder::new(E) + .custom_spec(test_spec::()) + .store(Arc::new(store)) + .dummy_eth1_backend() + .expect("should build dummy backend") + .slot_clock(SystemTimeSlotClock::new( + types::Slot::new(0), + Duration::from_secs( + SystemTime::now() + .duration_since(SystemTime::UNIX_EPOCH) + .unwrap() + .as_secs(), + ), + Duration::from_millis(400), + )) + .build() + .expect("should build"); + let log = { let decorator = slog_term::TermDecorator::new().build(); let drain = slog_term::FullFormat::new(decorator).build().fuse(); @@ -57,7 +86,7 @@ impl TestRig { network_tx, globals, beacon_processor_tx, - chain, + Arc::new(chain), log.new(slog::o!("component" => "network_context")), ) }; @@ -372,7 +401,15 @@ fn test_parent_lookup_rpc_failure() { let id1 = rig.expect_parent_request(); // The request fails. It should be tried again. - bl.parent_lookup_failed(id1, peer_id, &mut cx); + bl.parent_lookup_failed( + id1, + peer_id, + &mut cx, + RPCError::ErrorResponse( + RPCResponseErrorCode::ResourceUnavailable, + "older than eip4844".into(), + ), + ); let id2 = rig.expect_parent_request(); // Send the right block this time. @@ -406,7 +443,15 @@ fn test_parent_lookup_too_many_attempts() { // make sure every error is accounted for 0 => { // The request fails. It should be tried again. - bl.parent_lookup_failed(id, peer_id, &mut cx); + bl.parent_lookup_failed( + id, + peer_id, + &mut cx, + RPCError::ErrorResponse( + RPCResponseErrorCode::ResourceUnavailable, + "older than eip4844".into(), + ), + ); } _ => { // Send a bad block this time. It should be tried again. @@ -441,7 +486,15 @@ fn test_parent_lookup_too_many_download_attempts_no_blacklist() { let id = rig.expect_parent_request(); if i % 2 != 0 { // The request fails. It should be tried again. - bl.parent_lookup_failed(id, peer_id, &mut cx); + bl.parent_lookup_failed( + id, + peer_id, + &mut cx, + RPCError::ErrorResponse( + RPCResponseErrorCode::ResourceUnavailable, + "older than eip4844".into(), + ), + ); } else { // Send a bad block this time. It should be tried again. let bad_block = rig.rand_block(); @@ -475,7 +528,15 @@ fn test_parent_lookup_too_many_processing_attempts_must_blacklist() { for _ in 0..(parent_lookup::PARENT_FAIL_TOLERANCE - PROCESSING_FAILURES) { let id = rig.expect_parent_request(); // The request fails. It should be tried again. - bl.parent_lookup_failed(id, peer_id, &mut cx); + bl.parent_lookup_failed( + id, + peer_id, + &mut cx, + RPCError::ErrorResponse( + RPCResponseErrorCode::ResourceUnavailable, + "older than eip4844".into(), + ), + ); } // Now fail processing a block in the parent request @@ -638,12 +699,12 @@ fn test_same_chain_race_condition() { let peer_id = PeerId::random(); let trigger_block = blocks.pop().unwrap(); let chain_hash = trigger_block.canonical_root(); - bl.search_parent(chain_hash, trigger_block.clone(), peer_id, &mut cx); + bl.search_parent(chain_hash, trigger_block.clone().into(), peer_id, &mut cx); for (i, block) in blocks.into_iter().rev().enumerate() { let id = rig.expect_parent_request(); // the block - bl.parent_lookup_response(id, peer_id, Some(block.clone()), D, &mut cx); + bl.parent_lookup_response(id, peer_id, Some(block.clone().into()), D, &mut cx); // the stream termination bl.parent_lookup_response(id, peer_id, None, D, &mut cx); // the processing request @@ -653,7 +714,11 @@ fn test_same_chain_race_condition() { // one block was removed bl.parent_block_processed(chain_hash, BlockError::BlockIsAlreadyKnown.into(), &mut cx) } else { - bl.parent_block_processed(chain_hash, BlockError::ParentUnknown(block).into(), &mut cx) + bl.parent_block_processed( + chain_hash, + BlockError::ParentUnknown(block.into()).into(), + &mut cx, + ) } parent_lookups_consistency(&bl) } @@ -663,7 +728,7 @@ fn test_same_chain_race_condition() { // Try to get this block again while the chain is being processed. We should not request it again. let peer_id = PeerId::random(); - bl.search_parent(chain_hash, trigger_block, peer_id, &mut cx); + bl.search_parent(chain_hash, trigger_block.into(), peer_id, &mut cx); parent_lookups_consistency(&bl); let process_result = BatchProcessResult::Success {