From 9c9aa6c9fb70d487e00196ce09a10f36efc015af Mon Sep 17 00:00:00 2001 From: Arni Hod Date: Thu, 28 Nov 2024 15:42:41 +0200 Subject: [PATCH] chore(starknet_consensus_manager): set proposer address in propose block input --- .../papyrus_consensus/src/manager_test.rs | 27 ++++++---- .../src/single_height_consensus.rs | 25 +++++++-- .../src/single_height_consensus_test.rs | 14 ++--- .../papyrus_consensus/src/test_utils.rs | 8 ++- .../sequencing/papyrus_consensus/src/types.rs | 8 ++- .../src/papyrus_consensus_context.rs | 11 ++-- .../src/papyrus_consensus_context_test.rs | 21 ++++++-- .../src/sequencer_consensus_context.rs | 27 +++++++--- .../src/sequencer_consensus_context_test.rs | 53 +++++++++++-------- 9 files changed, 132 insertions(+), 62 deletions(-) diff --git a/crates/sequencing/papyrus_consensus/src/manager_test.rs b/crates/sequencing/papyrus_consensus/src/manager_test.rs index e4f03e65b03..4d8fd04f4a1 100644 --- a/crates/sequencing/papyrus_consensus/src/manager_test.rs +++ b/crates/sequencing/papyrus_consensus/src/manager_test.rs @@ -52,6 +52,7 @@ mock! { &mut self, height: BlockNumber, round: Round, + proposer: ValidatorId, timeout: Duration, content: mpsc::Receiver ) -> oneshot::Receiver; @@ -74,8 +75,12 @@ mock! { precommits: Vec, ) -> Result<(), ConsensusError>; - async fn set_height_and_round(&mut self, height: BlockNumber, round: Round); - + async fn set_height_and_round( + &mut self, + height: BlockNumber, + round: Round, + proposer: ValidatorId + ); } } @@ -107,7 +112,7 @@ async fn manager_multiple_heights_unordered() { // Run the manager for height 1. context .expect_validate_proposal() - .return_once(move |_, _, _, _| { + .return_once(move |_, _, _, _, _| { let (block_sender, block_receiver) = oneshot::channel(); block_sender.send(BlockHash(Felt::ONE)).unwrap(); block_receiver @@ -115,7 +120,7 @@ async fn manager_multiple_heights_unordered() { .times(1); context.expect_validators().returning(move |_| vec![*PROPOSER_ID, *VALIDATOR_ID]); context.expect_proposer().returning(move |_, _| *PROPOSER_ID); - context.expect_set_height_and_round().returning(move |_, _| ()); + context.expect_set_height_and_round().returning(move |_, _, _| ()); context.expect_broadcast().returning(move |_| Ok(())); let mut manager = MultiHeightManager::new(*VALIDATOR_ID, TIMEOUTS.clone()); @@ -134,7 +139,7 @@ async fn manager_multiple_heights_unordered() { // Run the manager for height 2. context .expect_validate_proposal() - .return_once(move |_, _, _, _| { + .return_once(move |_, _, _, _, _| { let (block_sender, block_receiver) = oneshot::channel(); block_sender.send(BlockHash(Felt::TWO)).unwrap(); block_receiver @@ -161,14 +166,14 @@ async fn run_consensus_sync() { // TODO(guyn): refactor this test to pass proposals through the correct channels. let (mut _proposal_receiver_sender, proposal_receiver_receiver) = mpsc::channel(CHANNEL_SIZE); - context.expect_validate_proposal().return_once(move |_, _, _, _| { + context.expect_validate_proposal().return_once(move |_, _, _, _, _| { let (block_sender, block_receiver) = oneshot::channel(); block_sender.send(BlockHash(Felt::TWO)).unwrap(); block_receiver }); context.expect_validators().returning(move |_| vec![*PROPOSER_ID, *VALIDATOR_ID]); context.expect_proposer().returning(move |_, _| *PROPOSER_ID); - context.expect_set_height_and_round().returning(move |_, _| ()); + context.expect_set_height_and_round().returning(move |_, _, _| ()); context.expect_broadcast().returning(move |_| Ok(())); context.expect_decision_reached().return_once(move |block, votes| { assert_eq!(block, BlockHash(Felt::TWO)); @@ -225,14 +230,14 @@ async fn run_consensus_sync_cancellation_safety() { // TODO(guyn): refactor this test to pass proposals through the correct channels. let (mut _proposal_receiver_sender, proposal_receiver_receiver) = mpsc::channel(CHANNEL_SIZE); - context.expect_validate_proposal().return_once(move |_, _, _, _| { + context.expect_validate_proposal().return_once(move |_, _, _, _, _| { let (block_sender, block_receiver) = oneshot::channel(); block_sender.send(BlockHash(Felt::ONE)).unwrap(); block_receiver }); context.expect_validators().returning(move |_| vec![*PROPOSER_ID, *VALIDATOR_ID]); context.expect_proposer().returning(move |_, _| *PROPOSER_ID); - context.expect_set_height_and_round().returning(move |_, _| ()); + context.expect_set_height_and_round().returning(move |_, _, _| ()); context.expect_broadcast().with(eq(prevote(Some(Felt::ONE), 1, 0, *VALIDATOR_ID))).return_once( move |_| { proposal_handled_tx.send(()).unwrap(); @@ -302,8 +307,8 @@ async fn test_timeouts() { send(&mut sender, precommit(None, 1, 0, *VALIDATOR_ID_3)).await; let mut context = MockTestContext::new(); - context.expect_set_height_and_round().returning(move |_, _| ()); - context.expect_validate_proposal().returning(move |_, _, _, _| { + context.expect_set_height_and_round().returning(move |_, _, _| ()); + context.expect_validate_proposal().returning(move |_, _, _, _, _| { let (block_sender, block_receiver) = oneshot::channel(); block_sender.send(BlockHash(Felt::ONE)).unwrap(); block_receiver diff --git a/crates/sequencing/papyrus_consensus/src/single_height_consensus.rs b/crates/sequencing/papyrus_consensus/src/single_height_consensus.rs index f24ef8922cf..f5bddfd1359 100644 --- a/crates/sequencing/papyrus_consensus/src/single_height_consensus.rs +++ b/crates/sequencing/papyrus_consensus/src/single_height_consensus.rs @@ -193,11 +193,15 @@ impl SingleHeightConsensus { context: &mut ContextT, ) -> Result { info!("Starting consensus with validators {:?}", self.validators); - context.set_height_and_round(self.height, self.state_machine.round()).await; + context + .set_height_and_round(self.height, self.state_machine.round(), ValidatorId::default()) + .await; let leader_fn = |round: Round| -> ValidatorId { context.proposer(self.height, round) }; let events = self.state_machine.start(&leader_fn); let ret = self.handle_state_machine_events(context, events).await; - context.set_height_and_round(self.height, self.state_machine.round()).await; + context + .set_height_and_round(self.height, self.state_machine.round(), ValidatorId::default()) + .await; ret } @@ -240,11 +244,14 @@ impl SingleHeightConsensus { .validate_proposal( self.height, init.round, + init.proposer, self.timeouts.proposal_timeout, p2p_messages_receiver, ) .await; - context.set_height_and_round(self.height, self.state_machine.round()).await; + context + .set_height_and_round(self.height, self.state_machine.round(), ValidatorId::default()) + .await; Ok(ShcReturn::Tasks(vec![ShcTask::ValidateProposal(init, block_receiver, fin_receiver)])) } @@ -272,7 +279,13 @@ impl SingleHeightConsensus { } ConsensusMessage::Vote(vote) => { let ret = self.handle_vote(context, vote).await; - context.set_height_and_round(self.height, self.state_machine.round()).await; + context + .set_height_and_round( + self.height, + self.state_machine.round(), + ValidatorId::default(), + ) + .await; ret } } @@ -359,7 +372,9 @@ impl SingleHeightConsensus { } _ => unimplemented!("Unexpected event: {:?}", event), }; - context.set_height_and_round(self.height, self.state_machine.round()).await; + context + .set_height_and_round(self.height, self.state_machine.round(), ValidatorId::default()) + .await; ret } diff --git a/crates/sequencing/papyrus_consensus/src/single_height_consensus_test.rs b/crates/sequencing/papyrus_consensus/src/single_height_consensus_test.rs index 3f0bd44856f..e391174bec9 100644 --- a/crates/sequencing/papyrus_consensus/src/single_height_consensus_test.rs +++ b/crates/sequencing/papyrus_consensus/src/single_height_consensus_test.rs @@ -94,7 +94,7 @@ async fn proposer() { block_sender.send(BLOCK.id).unwrap(); block_receiver }); - context.expect_set_height_and_round().returning(move |_, _| ()); + context.expect_set_height_and_round().returning(move |_, _, _| ()); context .expect_broadcast() .times(1) @@ -174,12 +174,12 @@ async fn validator(repeat_proposal: bool) { ); context.expect_proposer().returning(move |_, _| *PROPOSER_ID); - context.expect_validate_proposal().times(1).returning(move |_, _, _, _| { + context.expect_validate_proposal().times(1).returning(move |_, _, _, _, _| { let (block_sender, block_receiver) = oneshot::channel(); block_sender.send(BLOCK.id).unwrap(); block_receiver }); - context.expect_set_height_and_round().returning(move |_, _| ()); + context.expect_set_height_and_round().returning(move |_, _, _| ()); context .expect_broadcast() .times(1) @@ -253,12 +253,12 @@ async fn vote_twice(same_vote: bool) { ); context.expect_proposer().times(1).returning(move |_, _| *PROPOSER_ID); - context.expect_validate_proposal().times(1).returning(move |_, _, _, _| { + context.expect_validate_proposal().times(1).returning(move |_, _, _, _, _| { let (block_sender, block_receiver) = oneshot::channel(); block_sender.send(BLOCK.id).unwrap(); block_receiver }); - context.expect_set_height_and_round().returning(move |_, _| ()); + context.expect_set_height_and_round().returning(move |_, _, _| ()); context .expect_broadcast() .times(1) // Shows the repeat vote is ignored. @@ -327,7 +327,7 @@ async fn rebroadcast_votes() { block_sender.send(BLOCK.id).unwrap(); block_receiver }); - context.expect_set_height_and_round().returning(move |_, _| ()); + context.expect_set_height_and_round().returning(move |_, _, _| ()); context .expect_broadcast() .times(1) @@ -389,7 +389,7 @@ async fn repropose() { block_sender.send(BLOCK.id).unwrap(); block_receiver }); - context.expect_set_height_and_round().returning(move |_, _| ()); + context.expect_set_height_and_round().returning(move |_, _, _| ()); context .expect_broadcast() .times(1) diff --git a/crates/sequencing/papyrus_consensus/src/test_utils.rs b/crates/sequencing/papyrus_consensus/src/test_utils.rs index 37e51af60d1..ff455b0e0b8 100644 --- a/crates/sequencing/papyrus_consensus/src/test_utils.rs +++ b/crates/sequencing/papyrus_consensus/src/test_utils.rs @@ -42,6 +42,7 @@ mock! { &mut self, height: BlockNumber, round: Round, + proposer: ValidatorId, timeout: Duration, content: mpsc::Receiver ) -> oneshot::Receiver; @@ -64,7 +65,12 @@ mock! { precommits: Vec, ) -> Result<(), ConsensusError>; - async fn set_height_and_round(&mut self, height: BlockNumber, round: Round); + async fn set_height_and_round( + &mut self, + height: BlockNumber, + round: Round, + proposer: ValidatorId + ); } } diff --git a/crates/sequencing/papyrus_consensus/src/types.rs b/crates/sequencing/papyrus_consensus/src/types.rs index e1b8ce69362..b4cf1a2c0d2 100644 --- a/crates/sequencing/papyrus_consensus/src/types.rs +++ b/crates/sequencing/papyrus_consensus/src/types.rs @@ -76,6 +76,7 @@ pub trait ConsensusContext { &mut self, height: BlockNumber, round: Round, + proposer: ValidatorId, timeout: Duration, content: mpsc::Receiver, ) -> oneshot::Receiver; @@ -112,7 +113,12 @@ pub trait ConsensusContext { /// Update the context with the current height and round. /// Must be called at the beginning of each height. - async fn set_height_and_round(&mut self, height: BlockNumber, round: Round); + async fn set_height_and_round( + &mut self, + height: BlockNumber, + round: Round, + proposer: ValidatorId, + ); } #[derive(PartialEq)] diff --git a/crates/sequencing/papyrus_consensus_orchestrator/src/papyrus_consensus_context.rs b/crates/sequencing/papyrus_consensus_orchestrator/src/papyrus_consensus_context.rs index 4d5523be740..d1046a20f67 100644 --- a/crates/sequencing/papyrus_consensus_orchestrator/src/papyrus_consensus_context.rs +++ b/crates/sequencing/papyrus_consensus_orchestrator/src/papyrus_consensus_context.rs @@ -36,7 +36,6 @@ use papyrus_storage::body::BodyStorageReader; use papyrus_storage::header::HeaderStorageReader; use papyrus_storage::{StorageError, StorageReader}; use starknet_api::block::BlockNumber; -use starknet_api::core::ContractAddress; use starknet_api::transaction::Transaction; use tracing::{debug, debug_span, info, warn, Instrument}; @@ -70,7 +69,7 @@ impl PapyrusConsensusContext { storage_reader, network_broadcast_client, network_proposal_sender, - validators: (0..num_validators).map(ContractAddress::from).collect(), + validators: (0..num_validators).map(ValidatorId::from).collect(), sync_broadcast_sender, valid_proposals: Arc::new(Mutex::new(BTreeMap::new())), } @@ -167,6 +166,7 @@ impl ConsensusContext for PapyrusConsensusContext { &mut self, height: BlockNumber, _round: Round, + _proposer: ValidatorId, _timeout: Duration, mut content: mpsc::Receiver, ) -> oneshot::Receiver { @@ -287,7 +287,12 @@ impl ConsensusContext for PapyrusConsensusContext { Ok(()) } - async fn set_height_and_round(&mut self, _height: BlockNumber, _round: Round) { + async fn set_height_and_round( + &mut self, + _height: BlockNumber, + _round: Round, + _proposer: ValidatorId, + ) { // No-op } } diff --git a/crates/sequencing/papyrus_consensus_orchestrator/src/papyrus_consensus_context_test.rs b/crates/sequencing/papyrus_consensus_orchestrator/src/papyrus_consensus_context_test.rs index 25712fe2a70..cb63a53562f 100644 --- a/crates/sequencing/papyrus_consensus_orchestrator/src/papyrus_consensus_context_test.rs +++ b/crates/sequencing/papyrus_consensus_orchestrator/src/papyrus_consensus_context_test.rs @@ -3,7 +3,7 @@ use std::time::Duration; use futures::channel::{mpsc, oneshot}; use futures::StreamExt; use papyrus_consensus::stream_handler::StreamHandler; -use papyrus_consensus::types::ConsensusContext; +use papyrus_consensus::types::{ConsensusContext, ValidatorId}; use papyrus_network::network_manager::test_utils::{ mock_register_broadcast_topic, BroadcastNetworkMock, @@ -22,7 +22,6 @@ use papyrus_storage::header::HeaderStorageWriter; use papyrus_storage::test_utils::get_test_storage; use papyrus_test_utils::get_test_block; use starknet_api::block::{Block, BlockHash}; -use starknet_api::core::ContractAddress; use crate::papyrus_consensus_context::PapyrusConsensusContext; @@ -38,7 +37,7 @@ async fn build_proposal() { let proposal_init = ProposalInit { height: block_number, round: 0, - proposer: ContractAddress::default(), + proposer: ValidatorId::default(), valid_round: None, }; // TODO(Asmaa): Test proposal content. @@ -60,7 +59,13 @@ async fn validate_proposal_success() { validate_sender.close_channel(); let fin = papyrus_context - .validate_proposal(block_number, 0, Duration::MAX, validate_receiver) + .validate_proposal( + block_number, + 0, + ValidatorId::default(), + Duration::MAX, + validate_receiver, + ) .await .await .unwrap(); @@ -81,7 +86,13 @@ async fn validate_proposal_fail() { validate_sender.close_channel(); let fin = papyrus_context - .validate_proposal(block_number, 0, Duration::MAX, validate_receiver) + .validate_proposal( + block_number, + 0, + ValidatorId::default(), + Duration::MAX, + validate_receiver, + ) .await .await; assert_eq!(fin, Err(oneshot::Canceled)); diff --git a/crates/sequencing/papyrus_consensus_orchestrator/src/sequencer_consensus_context.rs b/crates/sequencing/papyrus_consensus_orchestrator/src/sequencer_consensus_context.rs index 078b76f5425..47f0118515c 100644 --- a/crates/sequencing/papyrus_consensus_orchestrator/src/sequencer_consensus_context.rs +++ b/crates/sequencing/papyrus_consensus_orchestrator/src/sequencer_consensus_context.rs @@ -139,7 +139,12 @@ impl ConsensusContext for SequencerConsensusContext { timeout: Duration, ) -> oneshot::Receiver { // Handles interrupting an active proposal from a previous height/round - self.set_height_and_round(proposal_init.height, proposal_init.round).await; + self.set_height_and_round( + proposal_init.height, + proposal_init.round, + proposal_init.proposer, + ) + .await; debug!( "Building proposal for height: {} with timeout: {:?}", proposal_init.height, timeout @@ -171,7 +176,7 @@ impl ConsensusContext for SequencerConsensusContext { now.timestamp().try_into().expect("Failed to convert timestamp"), ), use_kzg_da: true, - ..Default::default() + sequencer_address: proposal_init.proposer, }, }; // TODO: Should we be returning an error? @@ -215,6 +220,7 @@ impl ConsensusContext for SequencerConsensusContext { &mut self, height: BlockNumber, round: Round, + proposer: ValidatorId, timeout: Duration, content: mpsc::Receiver, ) -> oneshot::Receiver { @@ -227,7 +233,10 @@ impl ConsensusContext for SequencerConsensusContext { fin_receiver } std::cmp::Ordering::Equal => { - self.validate_current_round_proposal(height, timeout, content, fin_sender).await; + self.validate_current_round_proposal( + height, proposer, timeout, content, fin_sender, + ) + .await; fin_receiver } } @@ -284,7 +293,12 @@ impl ConsensusContext for SequencerConsensusContext { Ok(()) } - async fn set_height_and_round(&mut self, height: BlockNumber, round: Round) { + async fn set_height_and_round( + &mut self, + height: BlockNumber, + round: Round, + proposer: ValidatorId, + ) { if self.current_height.map(|h| height > h).unwrap_or(true) { self.current_height = Some(height); assert_eq!(round, 0); @@ -326,7 +340,7 @@ impl ConsensusContext for SequencerConsensusContext { let Some(((height, timeout, content), fin_sender)) = to_process else { return; }; - self.validate_current_round_proposal(height, timeout, content, fin_sender).await; + self.validate_current_round_proposal(height, proposer, timeout, content, fin_sender).await; } } @@ -334,6 +348,7 @@ impl SequencerConsensusContext { async fn validate_current_round_proposal( &mut self, height: BlockNumber, + proposer: ValidatorId, timeout: Duration, content: mpsc::Receiver>, fin_sender: oneshot::Sender, @@ -363,7 +378,7 @@ impl SequencerConsensusContext { now.timestamp().try_into().expect("Failed to convert timestamp"), ), use_kzg_da: true, - ..Default::default() + sequencer_address: proposer, }, }; batcher.validate_block(input).await.expect("Failed to initiate proposal validation"); diff --git a/crates/sequencing/papyrus_consensus_orchestrator/src/sequencer_consensus_context_test.rs b/crates/sequencing/papyrus_consensus_orchestrator/src/sequencer_consensus_context_test.rs index 8f718df3a09..60775933782 100644 --- a/crates/sequencing/papyrus_consensus_orchestrator/src/sequencer_consensus_context_test.rs +++ b/crates/sequencing/papyrus_consensus_orchestrator/src/sequencer_consensus_context_test.rs @@ -6,7 +6,7 @@ use futures::channel::mpsc; use futures::{FutureExt, SinkExt}; use lazy_static::lazy_static; use papyrus_consensus::stream_handler::StreamHandler; -use papyrus_consensus::types::ConsensusContext; +use papyrus_consensus::types::{ConsensusContext, ValidatorId}; use papyrus_network::network_manager::test_utils::{ mock_register_broadcast_topic, BroadcastNetworkMock, @@ -15,7 +15,7 @@ use papyrus_network::network_manager::test_utils::{ use papyrus_network::network_manager::BroadcastTopicChannels; use papyrus_protobuf::consensus::{ProposalInit, ProposalPart, StreamMessage}; use starknet_api::block::{BlockHash, BlockNumber}; -use starknet_api::core::{ContractAddress, StateDiffCommitment}; +use starknet_api::core::StateDiffCommitment; use starknet_api::executable_transaction::{AccountTransaction, Transaction}; use starknet_api::hash::PoseidonHash; use starknet_api::test_utils::invoke::{executable_invoke_tx, InvokeTxArgs}; @@ -114,7 +114,7 @@ async fn build_proposal() { let init = ProposalInit { height: BlockNumber(0), round: 0, - proposer: ContractAddress::default(), + proposer: ValidatorId::default(), valid_round: None, }; // TODO(Asmaa): Test proposal content. @@ -174,12 +174,13 @@ async fn validate_proposal_success() { NUM_VALIDATORS, ); // Initialize the context for a specific height, starting with round 0. - context.set_height_and_round(BlockNumber(0), 0).await; + context.set_height_and_round(BlockNumber(0), 0, ValidatorId::default()).await; let (mut content_sender, content_receiver) = mpsc::channel(CHANNEL_SIZE); content_sender.send(TX_BATCH.clone()).await.unwrap(); - let fin_receiver = - context.validate_proposal(BlockNumber(0), 0, TIMEOUT, content_receiver).await; + let fin_receiver = context + .validate_proposal(BlockNumber(0), 0, ValidatorId::default(), TIMEOUT, content_receiver) + .await; content_sender.close_channel(); assert_eq!(fin_receiver.await.unwrap().0, STATE_DIFF_COMMITMENT.0.0); } @@ -225,14 +226,15 @@ async fn repropose() { NUM_VALIDATORS, ); // Initialize the context for a specific height, starting with round 0. - context.set_height_and_round(BlockNumber(0), 0).await; + context.set_height_and_round(BlockNumber(0), 0, ValidatorId::default()).await; // Receive a valid proposal. let (mut content_sender, content_receiver) = mpsc::channel(CHANNEL_SIZE); let txs = vec![generate_invoke_tx(Felt::TWO)]; content_sender.send(txs.clone()).await.unwrap(); - let fin_receiver = - context.validate_proposal(BlockNumber(0), 0, TIMEOUT, content_receiver).await; + let fin_receiver = context + .validate_proposal(BlockNumber(0), 0, ValidatorId::default(), TIMEOUT, content_receiver) + .await; content_sender.close_channel(); assert_eq!(fin_receiver.await.unwrap().0, STATE_DIFF_COMMITMENT.0.0); @@ -296,30 +298,33 @@ async fn proposals_from_different_rounds() { NUM_VALIDATORS, ); // Initialize the context for a specific height, starting with round 0. - context.set_height_and_round(BlockNumber(0), 0).await; - context.set_height_and_round(BlockNumber(0), 1).await; + context.set_height_and_round(BlockNumber(0), 0, ValidatorId::default()).await; + context.set_height_and_round(BlockNumber(0), 1, ValidatorId::default()).await; // The proposal from the past round is ignored. let (mut content_sender, content_receiver) = mpsc::channel(CHANNEL_SIZE); content_sender.send(TX_BATCH.clone()).await.unwrap(); - let fin_receiver_past_round = - context.validate_proposal(BlockNumber(0), 0, TIMEOUT, content_receiver).await; + let fin_receiver_past_round = context + .validate_proposal(BlockNumber(0), 0, ValidatorId::default(), TIMEOUT, content_receiver) + .await; content_sender.close_channel(); assert!(fin_receiver_past_round.await.is_err()); // The proposal from the current round should be validated. let (mut content_sender, content_receiver) = mpsc::channel(CHANNEL_SIZE); content_sender.send(TX_BATCH.clone()).await.unwrap(); - let fin_receiver_curr_round = - context.validate_proposal(BlockNumber(0), 1, TIMEOUT, content_receiver).await; + let fin_receiver_curr_round = context + .validate_proposal(BlockNumber(0), 1, ValidatorId::default(), TIMEOUT, content_receiver) + .await; content_sender.close_channel(); assert_eq!(fin_receiver_curr_round.await.unwrap().0, STATE_DIFF_COMMITMENT.0.0); // The proposal from the future round should not be processed. let (mut content_sender, content_receiver) = mpsc::channel(CHANNEL_SIZE); content_sender.send(TX_BATCH.clone()).await.unwrap(); - let fin_receiver_future_round = - context.validate_proposal(BlockNumber(0), 2, TIMEOUT, content_receiver).await; + let fin_receiver_future_round = context + .validate_proposal(BlockNumber(0), 2, ValidatorId::default(), TIMEOUT, content_receiver) + .await; content_sender.close_channel(); assert!(fin_receiver_future_round.now_or_never().is_none()); } @@ -380,21 +385,23 @@ async fn interrupt_active_proposal() { NUM_VALIDATORS, ); // Initialize the context for a specific height, starting with round 0. - context.set_height_and_round(BlockNumber(0), 0).await; + context.set_height_and_round(BlockNumber(0), 0, ValidatorId::default()).await; // Keep the sender open, as closing it or sending Fin would cause the validate to complete // without needing interrupt. let (mut _content_sender_0, content_receiver) = mpsc::channel(CHANNEL_SIZE); - let fin_receiver_0 = - context.validate_proposal(BlockNumber(0), 0, TIMEOUT, content_receiver).await; + let fin_receiver_0 = context + .validate_proposal(BlockNumber(0), 0, ValidatorId::default(), TIMEOUT, content_receiver) + .await; let (mut content_sender_1, content_receiver) = mpsc::channel(CHANNEL_SIZE); content_sender_1.send(TX_BATCH.clone()).await.unwrap(); - let fin_receiver_1 = - context.validate_proposal(BlockNumber(0), 1, TIMEOUT, content_receiver).await; + let fin_receiver_1 = context + .validate_proposal(BlockNumber(0), 1, ValidatorId::default(), TIMEOUT, content_receiver) + .await; content_sender_1.close_channel(); // Move the context to the next round. - context.set_height_and_round(BlockNumber(0), 1).await; + context.set_height_and_round(BlockNumber(0), 1, ValidatorId::default()).await; // Interrupt active proposal. assert!(fin_receiver_0.await.is_err());