diff --git a/examples/demo-rollup/src/celestia_rollup.rs b/examples/demo-rollup/src/celestia_rollup.rs index 2352f1a0b..2f2864f38 100644 --- a/examples/demo-rollup/src/celestia_rollup.rs +++ b/examples/demo-rollup/src/celestia_rollup.rs @@ -42,6 +42,7 @@ impl RollupTemplate for CelestiaDemoRollup { fn create_genesis_config( &self, genesis_paths: &Self::GenesisPaths, + _rollup_config: &RollupConfig, ) -> Result<(), anyhow::Error> { match args.da_layer.as_str() { "mock" => { - let rollup = new_rollup_with_mock_da::>( + let rollup = new_rollup_with_mock_da( &GenesisPaths::from_dir("../test-data/genesis/integration-tests"), rollup_config_path, Some(RollupProverConfig::Execute), @@ -55,7 +53,7 @@ async fn main() -> Result<(), anyhow::Error> { rollup.run().await } "celestia" => { - let rollup = new_rollup_with_celestia_da::>( + let rollup = new_rollup_with_celestia_da( &GenesisPaths::from_dir("../test-data/genesis/demo-tests"), rollup_config_path, Some(RollupProverConfig::Execute), @@ -67,7 +65,7 @@ async fn main() -> Result<(), anyhow::Error> { } } -pub async fn new_rollup_with_celestia_da( +async fn new_rollup_with_celestia_da( genesis_paths: &GenesisPaths, rollup_config_path: &str, prover_config: Option, @@ -86,7 +84,7 @@ pub async fn new_rollup_with_celestia_da( .await } -pub async fn new_rollup_with_mock_da( +async fn new_rollup_with_mock_da( genesis_paths: &GenesisPaths, rollup_config_path: &str, prover_config: Option, diff --git a/examples/demo-rollup/src/mock_rollup.rs b/examples/demo-rollup/src/mock_rollup.rs index 58ef6d137..a511edfc2 100644 --- a/examples/demo-rollup/src/mock_rollup.rs +++ b/examples/demo-rollup/src/mock_rollup.rs @@ -9,9 +9,7 @@ use sov_modules_api::Spec; use sov_modules_rollup_template::RollupTemplate; use sov_modules_stf_template::Runtime as RuntimeTrait; use sov_risc0_adapter::host::Risc0Host; -use sov_rollup_interface::mocks::{ - MockAddress, MockDaConfig, MockDaService, MockDaSpec, MOCK_SEQUENCER_DA_ADDRESS, -}; +use sov_rollup_interface::mocks::{MockDaConfig, MockDaService, MockDaSpec}; use sov_rollup_interface::services::da::DaService; use sov_state::{ProverStorage, Storage, ZkStorage}; use sov_stf_runner::RollupConfig; @@ -41,15 +39,14 @@ impl RollupTemplate for MockDemoRollup { fn create_genesis_config( &self, genesis_paths: &Self::GenesisPaths, + rollup_config: &RollupConfig, ) -> >::GenesisConfig { - let sequencer_da_address = MockAddress::from(MOCK_SEQUENCER_DA_ADDRESS); - #[cfg(feature = "experimental")] let eth_signer = read_eth_tx_signers(); get_genesis_config( - sequencer_da_address, + rollup_config.da.sender_address, genesis_paths, #[cfg(feature = "experimental")] eth_signer.signers(), @@ -58,9 +55,9 @@ impl RollupTemplate for MockDemoRollup { async fn create_da_service( &self, - _rollup_config: &RollupConfig, + rollup_config: &RollupConfig, ) -> Self::DaService { - MockDaService::new(MockAddress::from(MOCK_SEQUENCER_DA_ADDRESS)) + MockDaService::new(rollup_config.da.sender_address) } fn create_vm(&self) -> Self::Vm { diff --git a/examples/demo-rollup/tests/bank/mod.rs b/examples/demo-rollup/tests/bank/mod.rs index 7f5de302f..454518c0b 100644 --- a/examples/demo-rollup/tests/bank/mod.rs +++ b/examples/demo-rollup/tests/bank/mod.rs @@ -18,6 +18,29 @@ use crate::test_helpers::start_rollup; const TOKEN_SALT: u64 = 0; const TOKEN_NAME: &str = "test_token"; +#[tokio::test] +async fn bank_tx_tests() -> Result<(), anyhow::Error> { + let (port_tx, port_rx) = tokio::sync::oneshot::channel(); + + let rollup_task = tokio::spawn(async { + start_rollup( + port_tx, + GenesisPaths::from_dir("../test-data/genesis/integration-tests"), + Some(RollupProverConfig::Execute), + ) + .await; + }); + + let port = port_rx.await.unwrap(); + + // If the rollup throws an error, return it and stop trying to send the transaction + tokio::select! { + err = rollup_task => err?, + res = send_test_create_token_tx(port) => res?, + }; + Ok(()) +} + async fn send_test_create_token_tx(rpc_address: SocketAddr) -> Result<(), anyhow::Error> { let key = DefaultPrivateKey::generate(); let user_address: ::Address = key.to_address(); @@ -65,26 +88,3 @@ async fn send_test_create_token_tx(rpc_address: SocketAddr) -> Result<(), anyhow assert_eq!(balance_response.amount.unwrap_or_default(), 1000); Ok(()) } - -#[tokio::test] -async fn bank_tx_tests() -> Result<(), anyhow::Error> { - let (port_tx, port_rx) = tokio::sync::oneshot::channel(); - - let rollup_task = tokio::spawn(async { - start_rollup( - port_tx, - GenesisPaths::from_dir("../test-data/genesis/integration-tests"), - Some(RollupProverConfig::Execute), - ) - .await; - }); - - let port = port_rx.await.unwrap(); - - // If the rollup throws an error, return it and stop trying to send the transaction - tokio::select! { - err = rollup_task => err?, - res = send_test_create_token_tx(port) => res?, - }; - Ok(()) -} diff --git a/module-system/sov-modules-rollup-template/src/lib.rs b/module-system/sov-modules-rollup-template/src/lib.rs index 3eeef534d..22da4eaec 100644 --- a/module-system/sov-modules-rollup-template/src/lib.rs +++ b/module-system/sov-modules-rollup-template/src/lib.rs @@ -52,6 +52,7 @@ pub trait RollupTemplate: Sized + Send + Sync { fn create_genesis_config( &self, genesis_paths: &Self::GenesisPaths, + rollup_config: &RollupConfig, ) -> >::GenesisConfig; /// Creates instance of DA Service. @@ -95,7 +96,7 @@ pub trait RollupTemplate: Sized + Send + Sync { { let da_service = self.create_da_service(&rollup_config).await; let ledger_db = self.create_ledger_db(&rollup_config); - let genesis_config = self.create_genesis_config(genesis_paths); + let genesis_config = self.create_genesis_config(genesis_paths, &rollup_config); let prover = prover_config.map(|pc| { configure_prover( diff --git a/sov-rollup-starter/.gitignore b/sov-rollup-starter/.gitignore new file mode 100644 index 000000000..e6031cf8f --- /dev/null +++ b/sov-rollup-starter/.gitignore @@ -0,0 +1 @@ +rollup-starter-data \ No newline at end of file diff --git a/sov-rollup-starter/provers/risc0/guest-mock/Cargo.lock b/sov-rollup-starter/provers/risc0/guest-mock/Cargo.lock index 2d87daccd..323955818 100644 --- a/sov-rollup-starter/provers/risc0/guest-mock/Cargo.lock +++ b/sov-rollup-starter/provers/risc0/guest-mock/Cargo.lock @@ -371,8 +371,11 @@ dependencies = [ "anyhow", "risc0-zkvm", "risc0-zkvm-platform", + "sov-modules-api", + "sov-modules-stf-template", "sov-risc0-adapter", "sov-rollup-interface", + "sov-state", "stf-starter", ] diff --git a/sov-rollup-starter/provers/risc0/guest-mock/Cargo.toml b/sov-rollup-starter/provers/risc0/guest-mock/Cargo.toml index 00a11dbdb..847bba3a8 100644 --- a/sov-rollup-starter/provers/risc0/guest-mock/Cargo.toml +++ b/sov-rollup-starter/provers/risc0/guest-mock/Cargo.toml @@ -10,10 +10,15 @@ resolver = "2" anyhow = "1.0.68" risc0-zkvm = { version = "0.18", default-features = false, features = ["std"] } risc0-zkvm-platform = "0.18" -stf-starter = { path = "../../../stf" } sov-risc0-adapter = { path = "../../../../adapters/risc0" } sov-rollup-interface = { path = "../../../../rollup-interface", features = ["mocks"] } +stf-starter = { path = "../../../stf" } + +sov-modules-api = { path = "../../../../module-system/sov-modules-api" } +sov-state = { path = "../../../../module-system/sov-state" } +sov-modules-stf-template = { path = "../../../../module-system/sov-modules-stf-template" } + [patch.crates-io] sha2 = { git = "https://github.com/risc0/RustCrypto-hashes", tag = "sha2/v0.10.6-risc0" } diff --git a/sov-rollup-starter/provers/risc0/guest-mock/src/bin/mock_da.rs b/sov-rollup-starter/provers/risc0/guest-mock/src/bin/mock_da.rs index 3ac2bcbc9..2ecd70cbc 100644 --- a/sov-rollup-starter/provers/risc0/guest-mock/src/bin/mock_da.rs +++ b/sov-rollup-starter/provers/risc0/guest-mock/src/bin/mock_da.rs @@ -1,6 +1,25 @@ #![no_main] //! This binary implements the verification logic for the rollup. This is the code that runs inside //! of the zkvm in order to generate proofs for the rollup. + +use sov_modules_api::default_context::ZkDefaultContext; +use sov_modules_stf_template::AppTemplate; +use sov_risc0_adapter::guest::Risc0Guest; +use sov_rollup_interface::mocks::MockDaVerifier; +use sov_state::ZkStorage; +use stf_starter::runtime::Runtime; +use stf_starter::AppVerifier; + risc0_zkvm::guest::entry!(main); -pub fn main() {} +pub fn main() { + let guest = Risc0Guest::new(); + let storage = ZkStorage::new(); + let app: AppTemplate> = AppTemplate::new(storage); + + let mut stf_verifier = AppVerifier::new(app, MockDaVerifier {}); + + stf_verifier + .run_block(guest) + .expect("Prover must be honest"); +} diff --git a/sov-rollup-starter/rollup_config.toml b/sov-rollup-starter/rollup_config.toml index 94fe44868..2e7ac5701 100644 --- a/sov-rollup-starter/rollup_config.toml +++ b/sov-rollup-starter/rollup_config.toml @@ -3,7 +3,7 @@ sender_address = "01010101010101010101010101010101010101010101010101010101010101 [storage] # The path to the rollup's data directory. Paths that do not begin with `/` are interpreted as relative paths. -path = "demo_data" +path = "rollup-starter-data" # We define the rollup's genesis to occur at block number `start_height`. The rollup will ignore # any blocks before this height diff --git a/sov-rollup-starter/src/bin/node.rs b/sov-rollup-starter/src/bin/node.rs index e7a2019ca..dc3c7cd22 100644 --- a/sov-rollup-starter/src/bin/node.rs +++ b/sov-rollup-starter/src/bin/node.rs @@ -1,54 +1,59 @@ //! This binary runs the rollup full node. -/* -use std::env; use std::path::PathBuf; +use std::str::FromStr; use anyhow::Context; -use sov_risc0_adapter::host::Risc0Host; -use sov_rollup_interface::mocks::{MockAddress, MOCK_SEQUENCER_DA_ADDRESS}; -use sov_rollup_starter::da::{start_da_service, DaConfig}; -use sov_rollup_starter::rollup::Rollup; +use clap::Parser; +use sov_modules_rollup_template::{Rollup, RollupProverConfig, RollupTemplate}; +use sov_rollup_interface::mocks::MockDaConfig; +use sov_rollup_starter::rollup::StarterRollup; use sov_stf_runner::{from_toml_path, RollupConfig}; -use stf_starter::{get_genesis_config, GenesisPaths}; +use stf_starter::genesis_config::GenesisPaths; use tracing::info; -use tracing_subscriber::filter::LevelFilter; -use tracing_subscriber::EnvFilter;*/ +use tracing_subscriber::prelude::*; +use tracing_subscriber::{fmt, EnvFilter}; + +#[derive(Parser, Debug)] +#[command(author, version, about, long_about = None)] +struct Args { + /// The path to the rollup config. + #[arg(long, default_value = "rollup_config.toml")] + rollup_config_path: String, +} #[tokio::main] async fn main() -> Result<(), anyhow::Error> { - /*// Initialize a logger for the demo - let subscriber = tracing_subscriber::fmt() - .with_env_filter( - EnvFilter::builder() - .with_default_directive(LevelFilter::INFO.into()) // If no logging config is set. default to `info` level logs - .from_env_lossy(), // Parse the log level from the RUST_LOG env var if set - ) // Try to override logging config from RUST_LOG env var - .finish(); - tracing::subscriber::set_global_default(subscriber) - .context("Unable to set global default subscriber")?; - - // Read the rollup config from a file - let rollup_config_path = env::args() - .nth(1) - .map(PathBuf::from) - .unwrap_or_else(|| PathBuf::from(env!("CARGO_MANIFEST_DIR")).join("rollup_config.toml")); + // Initializing logging + tracing_subscriber::registry() + .with(fmt::layer()) + .with(EnvFilter::from_str("debug,hyper=info").unwrap()) + .init(); + + let args = Args::parse(); + let rollup_config_path = args.rollup_config_path.as_str(); + + let rollup = new_rollup_with_mock_da( + &GenesisPaths::from_dir("test-data/genesis/"), + rollup_config_path, + Some(RollupProverConfig::Execute), + ) + .await?; + rollup.run().await +} + +async fn new_rollup_with_mock_da( + genesis_paths: &GenesisPaths, + rollup_config_path: &str, + prover_config: Option, +) -> Result, anyhow::Error> { info!("Reading rollup config from {rollup_config_path:?}"); - let rollup_config: RollupConfig = + let rollup_config: RollupConfig = from_toml_path(rollup_config_path).context("Failed to read rollup configuration")?; - info!("Initializing DA service"); - let da_service = start_da_service(&rollup_config).await; - - let sequencer_da_address = MockAddress::from(MOCK_SEQUENCER_DA_ADDRESS); - let genesis_paths = GenesisPaths::from_dir("../../test-data/genesis/"); - let genesis_config = get_genesis_config(sequencer_da_address, &genesis_paths); - - // Start rollup - let rollup: Rollup = - Rollup::new(da_service, genesis_config, rollup_config, None)?; - - rollup.run().await?;*/ - Ok(()) + let starter_rollup = StarterRollup {}; + starter_rollup + .create_new_rollup(genesis_paths, rollup_config, prover_config) + .await } diff --git a/sov-rollup-starter/src/da.rs b/sov-rollup-starter/src/da.rs deleted file mode 100644 index 0bea35f23..000000000 --- a/sov-rollup-starter/src/da.rs +++ /dev/null @@ -1,11 +0,0 @@ -//! This crate configures the da layer used by the rollup. -use sov_stf_runner::RollupConfig; -/// The type alias for the DA layer configuration. Change the contents of this alias if you change DA layers. -pub type DaConfig = sov_rollup_interface::mocks::MockDaConfig; -/// The type alias for the DA service. Change the contents of this alias if you change DA layers. -pub type DaService = sov_rollup_interface::mocks::MockDaService; - -/// Creates a new instance of the DA Service -pub async fn start_da_service(rollup_config: &RollupConfig) -> DaService { - DaService::new(rollup_config.da.sender_address) -} diff --git a/sov-rollup-starter/src/lib.rs b/sov-rollup-starter/src/lib.rs index 839788293..3b3bc2154 100644 --- a/sov-rollup-starter/src/lib.rs +++ b/sov-rollup-starter/src/lib.rs @@ -1,5 +1,4 @@ #![deny(missing_docs)] #![doc = include_str!("../README.md")] -pub mod da; -mod register_rpc; +mod register_sequencer; pub mod rollup; diff --git a/sov-rollup-starter/src/register_rpc.rs b/sov-rollup-starter/src/register_rpc.rs deleted file mode 100644 index c8a07e165..000000000 --- a/sov-rollup-starter/src/register_rpc.rs +++ /dev/null @@ -1,22 +0,0 @@ -use anyhow::Context; -use sov_modules_api::Zkvm; -use sov_rollup_interface::services::da::DaService; -use sov_sequencer::get_sequencer_rpc; -use stf_starter::StfWithBuilder; - -/// register sequencer rpc methods. -pub(crate) fn register_sequencer( - da_service: Da, - app: &mut StfWithBuilder, - methods: &mut jsonrpsee::RpcModule<()>, -) -> Result<(), anyhow::Error> -where - Da: DaService, - Vm: Zkvm, -{ - let batch_builder = app.batch_builder.take().unwrap(); - let sequencer_rpc = get_sequencer_rpc(batch_builder, da_service); - methods - .merge(sequencer_rpc) - .context("Failed to merge Txs RPC modules") -} diff --git a/sov-rollup-starter/src/register_sequencer.rs b/sov-rollup-starter/src/register_sequencer.rs new file mode 100644 index 000000000..15d116102 --- /dev/null +++ b/sov-rollup-starter/src/register_sequencer.rs @@ -0,0 +1,37 @@ +use anyhow::Context; +use sov_modules_api::default_context::DefaultContext; +use sov_modules_api::Spec; +use sov_rollup_interface::da::DaSpec; +use sov_rollup_interface::services::da::DaService; +use sov_sequencer::batch_builder::FiFoStrictBatchBuilder; +use sov_sequencer::get_sequencer_rpc; +use sov_state::ProverStorage; +use stf_starter::Runtime; + +/// register sequencer rpc methods. +pub(crate) fn register_sequencer( + storage: &::Storage, + da_service: Da, + methods: &mut jsonrpsee::RpcModule<()>, +) -> Result<(), anyhow::Error> +where + Da: DaService, +{ + let batch_builder = create_batch_builder::<::Spec>(storage.clone()); + let sequencer_rpc = get_sequencer_rpc(batch_builder, da_service); + methods + .merge(sequencer_rpc) + .context("Failed to merge Txs RPC modules") +} + +fn create_batch_builder( + storage: ProverStorage, +) -> FiFoStrictBatchBuilder, DefaultContext> { + let batch_size_bytes = 1024 * 100; // 100 KB + FiFoStrictBatchBuilder::new( + batch_size_bytes, + u32::MAX as usize, + Runtime::default(), + storage, + ) +} diff --git a/sov-rollup-starter/src/rollup.rs b/sov-rollup-starter/src/rollup.rs index 3669cb5c9..d067e35ba 100644 --- a/sov-rollup-starter/src/rollup.rs +++ b/sov-rollup-starter/src/rollup.rs @@ -1,33 +1,26 @@ //! Defines the rollup full node implementation, including logic for configuring //! and starting the rollup node. +use std::path::PathBuf; + use async_trait::async_trait; -use jsonrpsee::RpcModule; -use serde::de::DeserializeOwned; use sov_db::ledger_db::LedgerDB; use sov_modules_api::default_context::{DefaultContext, ZkDefaultContext}; use sov_modules_api::Spec; use sov_modules_rollup_template::RollupTemplate; -use sov_modules_stf_template::Runtime as RuntimeTrait; -use sov_modules_stf_template::{AppTemplate, SequencerOutcome, TxEffect}; +use sov_modules_stf_template::{Runtime as RuntimeTrait, SequencerOutcome, TxEffect}; use sov_risc0_adapter::host::Risc0Host; -use sov_rollup_interface::mocks::MockDaConfig; -use sov_rollup_interface::mocks::MockDaService; -use sov_rollup_interface::mocks::MockDaSpec; +use sov_rollup_interface::mocks::{MockDaConfig, MockDaService, MockDaSpec}; use sov_rollup_interface::services::da::DaService; -use sov_rollup_interface::zk::ZkvmHost; use sov_state::config::Config as StorageConfig; -use sov_state::storage::NativeStorage; -use sov_state::ProverStorage; -use sov_state::Storage; -use sov_state::ZkStorage; -use sov_stf_runner::{Prover, RollupConfig, RunnerConfig, StateTransitionRunner}; -use std::path::PathBuf; -use stf_starter::{get_genesis_config, GenesisPaths}; -use stf_starter::{get_rpc_methods, GenesisConfig, Runtime, StfWithBuilder}; -use tokio::sync::oneshot; +use sov_state::{ProverStorage, Storage, ZkStorage}; +use sov_stf_runner::RollupConfig; +use stf_starter::genesis_config::{get_genesis_config, GenesisPaths}; +use stf_starter::{get_rpc_methods, Runtime}; + +use crate::register_sequencer::register_sequencer; -///TODO +/// Rollup with MockDa. pub struct StarterRollup {} #[async_trait] @@ -48,10 +41,10 @@ impl RollupTemplate for StarterRollup { fn create_genesis_config( &self, genesis_paths: &Self::GenesisPaths, + rollup_config: &RollupConfig, ) -> >::GenesisConfig { - let sequencer_da_address = todo!(); - get_genesis_config(sequencer_da_address, genesis_paths) + get_genesis_config(rollup_config.da.sender_address, genesis_paths) } async fn create_da_service( @@ -62,8 +55,7 @@ impl RollupTemplate for StarterRollup { } fn create_vm(&self) -> Self::Vm { - //Risc0Host::new(risc0::MOCK_DA_ELF) - todo!() + Risc0Host::new(risc0_starter::MOCK_DA_ELF) } fn create_zk_storage( @@ -93,7 +85,15 @@ impl RollupTemplate for StarterRollup { ledger_db: &LedgerDB, da_service: &Self::DaService, ) -> Result, anyhow::Error> { - //create_rpc_methods(storage, ledger_db, da_service.clone()) - todo!() + let mut module = get_rpc_methods::(storage.clone()); + + module.merge(sov_ledger_rpc::server::rpc_module::< + LedgerDB, + SequencerOutcome<::Address>, + TxEffect, + >(ledger_db.clone())?)?; + + register_sequencer::(storage, da_service.clone(), &mut module)?; + Ok(module) } } diff --git a/sov-rollup-starter/stf/src/builder.rs b/sov-rollup-starter/stf/src/builder.rs deleted file mode 100644 index 87470d9fe..000000000 --- a/sov-rollup-starter/stf/src/builder.rs +++ /dev/null @@ -1,48 +0,0 @@ -//! This module implements the batch builder for the rollup. -//! To swap out the batch builder, simply replace the -//! FiFoStrictBatchBuilder in `StfWithBuilder` with a type of your choosing. -use sov_modules_api::default_context::DefaultContext; -#[cfg(feature = "native")] -use sov_modules_api::Spec; -use sov_modules_api::{DaSpec, Zkvm}; -use sov_modules_stf_template::AppTemplate; -#[cfg(feature = "native")] -use sov_sequencer::batch_builder::FiFoStrictBatchBuilder; -#[cfg(feature = "native")] -use sov_state::{ProverStorage, Storage}; - -use super::runtime::Runtime; - -/// The "native" version of the STF and a batch builder -pub struct StfWithBuilder { - pub stf: AppTemplate>, - pub batch_builder: Option, DefaultContext>>, -} - -#[cfg(feature = "native")] -impl StfWithBuilder { - /// Create a new rollup instance - pub fn new(storage_config: sov_stf_runner::StorageConfig) -> Self { - let config = sov_state::config::Config { - path: storage_config.path, - }; - - let storage = ProverStorage::with_config(config).expect("Failed to open prover storage"); - let app = AppTemplate::new(storage.clone()); - let batch_size_bytes = 1024 * 100; // 100 KB - let batch_builder = FiFoStrictBatchBuilder::new( - batch_size_bytes, - u32::MAX as usize, - Runtime::default(), - storage, - ); - Self { - stf: app, - batch_builder: Some(batch_builder), - } - } - - pub fn get_storage(&self) -> ::Storage { - self.stf.current_storage.clone() - } -} diff --git a/sov-rollup-starter/stf/src/lib.rs b/sov-rollup-starter/stf/src/lib.rs index 0e88e28a9..155d8c492 100644 --- a/sov-rollup-starter/stf/src/lib.rs +++ b/sov-rollup-starter/stf/src/lib.rs @@ -1,13 +1,13 @@ //! The rollup State Transition Function. #[cfg(feature = "native")] -mod builder; -#[cfg(feature = "native")] -mod genesis_config; +pub mod genesis_config; mod hooks; -mod runtime; - -#[cfg(feature = "native")] -pub use builder::*; -#[cfg(feature = "native")] -pub use genesis_config::*; +pub mod runtime; pub use runtime::*; +use sov_modules_stf_template::AppTemplate; +use sov_rollup_interface::da::DaVerifier; +use sov_stf_runner::verifier::StateTransitionVerifier; + +/// Alias for StateTransitionVerifier. +pub type AppVerifier = + StateTransitionVerifier::Spec, Vm, RT>, DA, Vm>; diff --git a/sov-rollup-starter/tests/bank/mod.rs b/sov-rollup-starter/tests/bank/mod.rs index b6aabd9d0..1b3b38bf5 100644 --- a/sov-rollup-starter/tests/bank/mod.rs +++ b/sov-rollup-starter/tests/bank/mod.rs @@ -7,16 +7,40 @@ use sov_modules_api::default_context::DefaultContext; use sov_modules_api::default_signature::private_key::DefaultPrivateKey; use sov_modules_api::transaction::Transaction; use sov_modules_api::{PrivateKey, Spec}; -use sov_risc0_adapter::host::Risc0Host; +use sov_modules_rollup_template::RollupProverConfig; use sov_rollup_interface::mocks::MockDaSpec; use sov_sequencer::utils::SimpleClient; -use stf_starter::{GenesisPaths, RuntimeCall}; +use stf_starter::genesis_config::GenesisPaths; +use stf_starter::RuntimeCall; use super::test_helpers::start_rollup; const TOKEN_SALT: u64 = 0; const TOKEN_NAME: &str = "test_token"; +#[tokio::test] +async fn bank_tx_tests() -> Result<(), anyhow::Error> { + let (port_tx, port_rx) = tokio::sync::oneshot::channel(); + + let rollup_task = tokio::spawn(async { + start_rollup( + port_tx, + GenesisPaths::from_dir("test-data/genesis/"), + Some(RollupProverConfig::Execute), + ) + .await; + }); + + let port = port_rx.await.unwrap(); + + // If the rollup throws an error, return it and stop trying to send the transaction + tokio::select! { + err = rollup_task => err?, + res = send_test_create_token_tx(port) => res?, + }; + Ok(()) +} + async fn send_test_create_token_tx(rpc_address: SocketAddr) -> Result<(), anyhow::Error> { let key = DefaultPrivateKey::generate(); let user_address: ::Address = key.to_address(); @@ -64,26 +88,3 @@ async fn send_test_create_token_tx(rpc_address: SocketAddr) -> Result<(), anyhow assert_eq!(balance_response.amount.unwrap_or_default(), 1000); Ok(()) } - -#[tokio::test] -async fn bank_tx_tests() -> Result<(), anyhow::Error> { - let (port_tx, port_rx) = tokio::sync::oneshot::channel(); - - let rollup_task = tokio::spawn(async { - start_rollup::, _>( - port_tx, - &GenesisPaths::from_dir("test-data/genesis/"), - ) - .await; - }); - - // Wait for rollup task to start: - let port = port_rx.await.unwrap(); - - // If the rollup throws an error, return it and stop trying to send the transaction - tokio::select! { - err = rollup_task => err?, - res = send_test_create_token_tx(port) => res?, - }; - Ok(()) -} diff --git a/sov-rollup-starter/tests/test_helpers.rs b/sov-rollup-starter/tests/test_helpers.rs index f92f6da18..cade8b16b 100644 --- a/sov-rollup-starter/tests/test_helpers.rs +++ b/sov-rollup-starter/tests/test_helpers.rs @@ -1,26 +1,21 @@ use std::net::SocketAddr; -use std::path::Path; +use std::path::PathBuf; -use sov_rollup_interface::mocks::{ - MockAddress, MockDaConfig, MockDaService, MOCK_SEQUENCER_DA_ADDRESS, -}; -use sov_rollup_interface::zk::ZkvmHost; -use sov_rollup_starter::rollup::Rollup; +use sov_modules_rollup_template::{RollupProverConfig, RollupTemplate}; +use sov_rollup_interface::mocks::{MockAddress, MockDaConfig}; +use sov_rollup_starter::rollup::StarterRollup; use sov_stf_runner::{RollupConfig, RpcConfig, RunnerConfig, StorageConfig}; -use stf_starter::{get_genesis_config, GenesisPaths}; +use stf_starter::genesis_config::GenesisPaths; use tokio::sync::oneshot; -pub async fn start_rollup>( +pub async fn start_rollup( rpc_reporting_channel: oneshot::Sender, - genesis_paths: &GenesisPaths

, + genesis_paths: GenesisPaths, + rollup_prover_config: Option, ) { let temp_dir = tempfile::tempdir().unwrap(); let temp_path = temp_dir.path(); - let sequencer_da_address = MockAddress::from(MOCK_SEQUENCER_DA_ADDRESS); - - let genesis_config = get_genesis_config(sequencer_da_address, genesis_paths); - let rollup_config = RollupConfig { storage: StorageConfig { path: temp_path.to_path_buf(), @@ -33,17 +28,16 @@ pub async fn start_rollup>( }, }, da: MockDaConfig { - sender_address: genesis_config.sequencer_registry.seq_da_address, + sender_address: MockAddress { addr: [0; 32] }, }, }; - let rollup = Rollup::::new( - MockDaService::new(genesis_config.sequencer_registry.seq_da_address), - genesis_config, - rollup_config, - None, - ) - .unwrap(); + let starter_rollup = StarterRollup {}; + + let rollup = starter_rollup + .create_new_rollup(&genesis_paths, rollup_config, rollup_prover_config) + .await + .unwrap(); rollup .run_and_report_rpc_port(Some(rpc_reporting_channel))