From 60b70c2b1322030a02a285f24be885b963acdafc Mon Sep 17 00:00:00 2001 From: Yair Bakalchuk Date: Tue, 3 Dec 2024 12:48:57 +0200 Subject: [PATCH] refactor(starknet_integration_tests): separete node creation from test setup --- .../src/network_manager/test_utils.rs | 2 +- .../src/flow_test_setup.rs | 107 +++++++++++++----- .../src/integration_test_setup.rs | 22 +++- .../starknet_integration_tests/src/utils.rs | 12 +- .../tests/end_to_end_flow_test.rs | 5 +- 5 files changed, 107 insertions(+), 41 deletions(-) diff --git a/crates/papyrus_network/src/network_manager/test_utils.rs b/crates/papyrus_network/src/network_manager/test_utils.rs index e7b59e4695..be1f65427b 100644 --- a/crates/papyrus_network/src/network_manager/test_utils.rs +++ b/crates/papyrus_network/src/network_manager/test_utils.rs @@ -188,7 +188,7 @@ where const BUFFER_SIZE: usize = 1000; let mut channels_configs = create_connected_network_configs(n_configs + 1); - let broadcast_channels = channels_configs.pop().unwrap(); + let broadcast_channels = channels_configs.remove(0); let mut channels_network_manager = NetworkManager::new(broadcast_channels, None); let broadcast_channels = diff --git a/crates/starknet_integration_tests/src/flow_test_setup.rs b/crates/starknet_integration_tests/src/flow_test_setup.rs index 4aed6aca04..c9102f0150 100644 --- a/crates/starknet_integration_tests/src/flow_test_setup.rs +++ b/crates/starknet_integration_tests/src/flow_test_setup.rs @@ -1,51 +1,103 @@ use std::net::SocketAddr; -use mempool_test_utils::starknet_api_test_utils::MultiAccountTransactionGenerator; +use blockifier::context::ChainInfo; +use mempool_test_utils::starknet_api_test_utils::{Contract, MultiAccountTransactionGenerator}; use papyrus_network::network_manager::BroadcastTopicChannels; use papyrus_protobuf::consensus::{ProposalPart, StreamMessage}; use starknet_api::rpc_transaction::RpcTransaction; use starknet_api::transaction::TransactionHash; +use starknet_consensus_manager::config::ConsensusManagerConfig; use starknet_gateway_types::errors::GatewaySpecError; use starknet_http_server::config::HttpServerConfig; use starknet_http_server::test_utils::HttpTestClient; -use starknet_sequencer_infra::trace_util::configure_tracing; use starknet_sequencer_node::servers::run_component_servers; use starknet_sequencer_node::utils::create_node_modules; use starknet_task_executor::tokio_executor::TokioExecutor; use tempfile::TempDir; use tokio::runtime::Handle; use tokio::task::JoinHandle; +use tracing::{debug, instrument}; use crate::state_reader::{spawn_test_rpc_state_reader, StorageTestSetup}; -use crate::utils::{create_chain_info, create_config}; +use crate::utils::{ + create_chain_info, + create_config, + create_consensus_manager_configs_and_channels, +}; + +const PROPOSER_ID: usize = 0; +const SEQUENCER_IDS: [usize; 1] = [PROPOSER_ID]; pub struct FlowTestSetup { + // TODO(Tsabary): Remove this field. pub task_executor: TokioExecutor, - - // Client for adding transactions to the sequencer node. - pub add_tx_http_client: HttpTestClient, - - // Handlers for the storage files, maintained so the files are not deleted. - pub batcher_storage_file_handle: TempDir, - pub rpc_storage_file_handle: TempDir, - - // Handle of the sequencer node. - pub sequencer_node_handle: JoinHandle>, + pub proposer: SequencerSetup, // Channels for consensus proposals, used for asserting the right transactions are proposed. pub consensus_proposals_channels: BroadcastTopicChannels>, } impl FlowTestSetup { + #[instrument(skip(tx_generator), level = "debug")] pub async fn new_from_tx_generator(tx_generator: &MultiAccountTransactionGenerator) -> Self { let handle = Handle::current(); let task_executor = TokioExecutor::new(handle); let chain_info = create_chain_info(); - // Configure and start tracing. - configure_tracing(); - let accounts = tx_generator.accounts(); + let (mut consensus_manager_configs, consensus_proposals_channels) = + create_consensus_manager_configs_and_channels(SEQUENCER_IDS.len()); + + // Take the first config for every sequencer node. + let proposer_consensus_manager_config = consensus_manager_configs.remove(0); + let proposer = SequencerSetup::new( + accounts.clone(), + PROPOSER_ID, + chain_info.clone(), + &task_executor, + proposer_consensus_manager_config, + ) + .await; + + Self { task_executor, proposer, consensus_proposals_channels } + } + + pub async fn assert_add_tx_success(&self, tx: RpcTransaction) -> TransactionHash { + self.proposer.add_tx_http_client.assert_add_tx_success(tx).await + } + + pub async fn assert_add_tx_error(&self, tx: RpcTransaction) -> GatewaySpecError { + self.proposer.add_tx_http_client.assert_add_tx_error(tx).await + } +} + +pub struct SequencerSetup { + /// Used to differentiate between different sequencer nodes. + pub sequencer_id: usize, + + // Client for adding transactions to the sequencer node. + pub add_tx_http_client: HttpTestClient, + + // Handlers for the storage files, maintained so the files are not deleted. + pub batcher_storage_file_handle: TempDir, + pub rpc_storage_file_handle: TempDir, + + // Handle of the sequencer node. + pub sequencer_node_handle: JoinHandle>, +} + +impl SequencerSetup { + #[instrument( + skip(accounts, chain_info, task_executor, consensus_manager_config), + level = "debug" + )] + pub async fn new( + accounts: Vec, + sequencer_id: usize, + chain_info: ChainInfo, + task_executor: &TokioExecutor, + consensus_manager_config: ConsensusManagerConfig, + ) -> Self { let storage_for_test = StorageTestSetup::new(accounts, &chain_info); // Spawn a papyrus rpc server for a papyrus storage reader. @@ -56,9 +108,15 @@ impl FlowTestSetup { .await; // Derive the configuration for the sequencer node. - let (config, _required_params, consensus_proposals_channels) = - create_config(chain_info, rpc_server_addr, storage_for_test.batcher_storage_config) - .await; + let (config, _required_params) = create_config( + chain_info, + rpc_server_addr, + storage_for_test.batcher_storage_config, + consensus_manager_config, + ) + .await; + + debug!("Sequencer config: {:#?}", config); let (_clients, servers) = create_node_modules(&config); @@ -75,20 +133,11 @@ impl FlowTestSetup { tokio::time::sleep(std::time::Duration::from_millis(100)).await; Self { - task_executor, + sequencer_id, add_tx_http_client, batcher_storage_file_handle: storage_for_test.batcher_storage_handle, rpc_storage_file_handle: storage_for_test.rpc_storage_handle, sequencer_node_handle, - consensus_proposals_channels, } } - - pub async fn assert_add_tx_success(&self, tx: RpcTransaction) -> TransactionHash { - self.add_tx_http_client.assert_add_tx_success(tx).await - } - - pub async fn assert_add_tx_error(&self, tx: RpcTransaction) -> GatewaySpecError { - self.add_tx_http_client.assert_add_tx_error(tx).await - } } diff --git a/crates/starknet_integration_tests/src/integration_test_setup.rs b/crates/starknet_integration_tests/src/integration_test_setup.rs index 08d1f930d0..ba6ca3ffff 100644 --- a/crates/starknet_integration_tests/src/integration_test_setup.rs +++ b/crates/starknet_integration_tests/src/integration_test_setup.rs @@ -11,7 +11,14 @@ use tempfile::{tempdir, TempDir}; use crate::config_utils::dump_config_file_changes; use crate::state_reader::{spawn_test_rpc_state_reader, StorageTestSetup}; -use crate::utils::{create_chain_info, create_config}; +use crate::utils::{ + create_chain_info, + create_config, + create_consensus_manager_configs_and_channels, +}; + +const SEQUENCER_ID: usize = 0; +const SEQUENCER_IDS: [usize; 1] = [SEQUENCER_ID]; pub struct IntegrationTestSetup { // Client for adding transactions to the sequencer node. @@ -46,10 +53,17 @@ impl IntegrationTestSetup { ) .await; + let (mut consensus_manager_configs, _consensus_proposals_channels) = + create_consensus_manager_configs_and_channels(SEQUENCER_IDS.len()); + // Derive the configuration for the sequencer node. - let (config, required_params, _) = - create_config(chain_info, rpc_server_addr, storage_for_test.batcher_storage_config) - .await; + let (config, required_params) = create_config( + chain_info, + rpc_server_addr, + storage_for_test.batcher_storage_config, + consensus_manager_configs.pop().unwrap(), + ) + .await; let node_config_dir_handle = tempdir().unwrap(); let node_config_path = dump_config_file_changes( diff --git a/crates/starknet_integration_tests/src/utils.rs b/crates/starknet_integration_tests/src/utils.rs index 2cbf630e05..2595a2c176 100644 --- a/crates/starknet_integration_tests/src/utils.rs +++ b/crates/starknet_integration_tests/src/utils.rs @@ -36,19 +36,20 @@ pub fn create_chain_info() -> ChainInfo { chain_info } +// TODO(yair, Tsabary): Create config presets for tests, then remove all the functions that modify +// the config. pub async fn create_config( chain_info: ChainInfo, rpc_server_addr: SocketAddr, batcher_storage_config: StorageConfig, -) -> (SequencerNodeConfig, RequiredParams, BroadcastTopicChannels>) { + consensus_manager_config: ConsensusManagerConfig, +) -> (SequencerNodeConfig, RequiredParams) { let fee_token_addresses = chain_info.fee_token_addresses.clone(); let batcher_config = create_batcher_config(batcher_storage_config, chain_info.clone()); let gateway_config = create_gateway_config(chain_info.clone()).await; let http_server_config = create_http_server_config().await; let rpc_state_reader_config = test_rpc_state_reader_config(rpc_server_addr); - let (mut consensus_manager_configs, consensus_proposals_channels) = - create_consensus_manager_configs_and_channels(1); - let consensus_manager_config = consensus_manager_configs.pop().unwrap(); + ( SequencerNodeConfig { batcher_config, @@ -63,11 +64,10 @@ pub async fn create_config( eth_fee_token_address: fee_token_addresses.eth_fee_token_address, strk_fee_token_address: fee_token_addresses.strk_fee_token_address, }, - consensus_proposals_channels, ) } -fn create_consensus_manager_configs_and_channels( +pub fn create_consensus_manager_configs_and_channels( n_managers: usize, ) -> (Vec, BroadcastTopicChannels>) { let (network_configs, broadcast_channels) = diff --git a/crates/starknet_integration_tests/tests/end_to_end_flow_test.rs b/crates/starknet_integration_tests/tests/end_to_end_flow_test.rs index e648c437ba..6741c362a9 100644 --- a/crates/starknet_integration_tests/tests/end_to_end_flow_test.rs +++ b/crates/starknet_integration_tests/tests/end_to_end_flow_test.rs @@ -21,6 +21,7 @@ use starknet_integration_tests::utils::{ create_integration_test_tx_generator, run_integration_test_scenario, }; +use starknet_sequencer_infra::trace_util::configure_tracing; use starknet_types_core::felt::Felt; use tracing::debug; @@ -34,7 +35,9 @@ fn tx_generator() -> MultiAccountTransactionGenerator { #[rstest] #[tokio::test] -async fn end_to_end(mut tx_generator: MultiAccountTransactionGenerator) { +async fn end_to_end_flow(mut tx_generator: MultiAccountTransactionGenerator) { + configure_tracing(); + const LISTEN_TO_BROADCAST_MESSAGES_TIMEOUT: std::time::Duration = std::time::Duration::from_secs(5); // Setup.