From a3831f24dab038d7ea213ca1354299d926f880db Mon Sep 17 00:00:00 2001 From: viquezclaudio Date: Fri, 6 Dec 2024 14:09:14 -0600 Subject: [PATCH] Fix skip block unittest Fix the skip block unittest to actually produce skip blocks and verify this --- validator/tests/mock.rs | 34 +++++++++++++++------------------- 1 file changed, 15 insertions(+), 19 deletions(-) diff --git a/validator/tests/mock.rs b/validator/tests/mock.rs index 92e0510fcb..a16dfd1141 100644 --- a/validator/tests/mock.rs +++ b/validator/tests/mock.rs @@ -139,28 +139,20 @@ async fn four_validators_can_create_micro_blocks() { } #[test(tokio::test)] -async fn four_validators_can_do_skip_block() { - let hub = MockHub::default(); +async fn validators_can_do_skip_block() { let env = MdbxDatabase::new_volatile(Default::default()).expect("Could not open a volatile database"); - let mut validators = build_validators::( - env, - &(5u64..=8u64).collect::>(), - &mut Some(hub), - false, - ) - .await; + let mut validators = + build_validators::(env, &(5u64..=10u64).collect::>(), &mut None, false) + .await; // Disconnect the next block producer. - let validator = pop_validator_for_slot(&mut validators, 1 + Policy::genesis_block_number(), 1); - validator - .consensus - .network - .disconnect(CloseReason::GoingOffline) - .await; - drop(validator); - log::info!("Peer disconnection"); + let _validator = pop_validator_for_slot( + &mut validators, + 1 + Policy::genesis_block_number(), + 1 + Policy::genesis_block_number(), + ); // Listen for blockchain events from the new block producer (after a skip block). let validator = validators.first().unwrap(); @@ -174,10 +166,14 @@ async fn four_validators_can_do_skip_block() { spawn(validator); } - // Wait for the new block producer to create a block. + // Wait for the new block producer to create a skip block. events.next().await; - assert!(blockchain.read().block_number() > Policy::genesis_block_number()); + // Verify the skip block was produced: + let block = blockchain.read().head().clone(); + + assert!(block.is_skip()); + assert!(block.block_number() > Policy::genesis_block_number()); } fn create_skip_block_update(