diff --git a/.github/workflows/rust.yml b/.github/workflows/rust.yml index 6e87e2d86..a2d8e66a8 100644 --- a/.github/workflows/rust.yml +++ b/.github/workflows/rust.yml @@ -17,16 +17,15 @@ jobs: check: runs-on: ubuntu-latest name: check + timeout-minutes: 60 env: RUSTFLAGS: -D warnings SCCACHE_GHA_ENABLED: "true" RUSTC_WRAPPER: "sccache" steps: - uses: actions/checkout@v3 - - name: Run sccache-cache - uses: mozilla-actions/sccache-action@v0.0.3 - with: - version: "v0.4.0" + - uses: Swatinem/rust-cache@v2 + - uses: mozilla-actions/sccache-action@v0.0.3 - name: Run lint run: | if ! make lint ; then @@ -39,16 +38,15 @@ jobs: check-demo-prover: runs-on: ubuntu-latest name: check demo prover + timeout-minutes: 90 env: RUSTFLAGS: -D warnings SCCACHE_GHA_ENABLED: "true" RUSTC_WRAPPER: "sccache" steps: - uses: actions/checkout@v3 - - name: Run sccache-cache - uses: mozilla-actions/sccache-action@v0.0.3 - with: - version: "v0.4.0" + - uses: Swatinem/rust-cache@v2 + - uses: mozilla-actions/sccache-action@v0.0.3 - name: Run cargo check run: cd examples/demo-prover && cargo check - name: Run cargo fmt check @@ -63,14 +61,15 @@ jobs: hack: runs-on: ubuntu-latest name: features + timeout-minutes: 60 env: RUSTFLAGS: -D warnings SCCACHE_GHA_ENABLED: "true" RUSTC_WRAPPER: "sccache" steps: - uses: actions/checkout@v3 - - name: Run sccache-cache - uses: mozilla-actions/sccache-action@v0.0.3 + - uses: Swatinem/rust-cache@v2 + - uses: mozilla-actions/sccache-action@v0.0.3 - name: cargo install cargo-hack uses: taiki-e/install-action@cargo-hack # intentionally no target specifier; see https://github.com/jonhoo/rust-ci-conf/pull/4 @@ -78,19 +77,19 @@ jobs: run: make check-features test: runs-on: ubuntu-latest + timeout-minutes: 60 env: SCCACHE_GHA_ENABLED: "true" RUSTC_WRAPPER: "sccache" steps: - uses: actions/checkout@v3 - - name: Run sccache-cache - uses: mozilla-actions/sccache-action@v0.0.3 - with: - version: "v0.4.0" + - uses: Swatinem/rust-cache@v2 + - uses: mozilla-actions/sccache-action@v0.0.3 - name: Run cargo test run: cargo test coverage: runs-on: ubuntu-latest + timeout-minutes: 90 env: SCCACHE_GHA_ENABLED: "true" RUSTC_WRAPPER: "sccache" @@ -100,8 +99,8 @@ jobs: submodules: true - name: add llvm component run: rustup component add llvm-tools-preview - - name: Run sccache-cache - uses: mozilla-actions/sccache-action@v0.0.3 + - uses: Swatinem/rust-cache@v2 + - uses: mozilla-actions/sccache-action@v0.0.3 - name: cargo install cargo-llvm-cov uses: taiki-e/install-action@cargo-llvm-cov - name: cargo generate-lockfile diff --git a/Makefile b/Makefile index 8f6a45fd4..4fce3a52f 100644 --- a/Makefile +++ b/Makefile @@ -10,7 +10,7 @@ clean: ## Cleans compiled @cargo clean test: ## Runs test suite with output from tests printed - @cargo test -- --nocapture + @cargo test -- --nocapture -Zunstable-options --report-time install-dev-tools: ## Installs all necessary cargo helpers cargo install cargo-llvm-cov diff --git a/examples/demo-stf/src/tests/stf_tests.rs b/examples/demo-stf/src/tests/stf_tests.rs index 8362541bb..1af6bbd52 100644 --- a/examples/demo-stf/src/tests/stf_tests.rs +++ b/examples/demo-stf/src/tests/stf_tests.rs @@ -40,8 +40,9 @@ pub mod test { None, ); - assert!( - matches!(apply_blob_outcome.inner, SequencerOutcome::Rewarded(0),), + assert_eq!( + SequencerOutcome::Rewarded(0), + apply_blob_outcome.inner, "Sequencer execution should have succeeded but failed " ); @@ -97,9 +98,10 @@ pub mod test { None, ); - assert!( - matches!(apply_blob_outcome.inner, SequencerOutcome::Rewarded(0),), - "Sequencer execution should have succeeded but failed " + assert_eq!( + SequencerOutcome::Rewarded(0), + apply_blob_outcome.inner, + "Sequencer execution should have succeeded but failed" ); assert!(has_tx_events(&apply_blob_outcome),); @@ -151,9 +153,10 @@ pub mod test { None, ) .inner; - assert!( - matches!(apply_blob_outcome, SequencerOutcome::Rewarded(0),), - "Sequencer execution should have succeeded but failed " + assert_eq!( + SequencerOutcome::Rewarded(0), + apply_blob_outcome, + "Sequencer execution should have succeeded but failed", ); } @@ -197,15 +200,16 @@ pub mod test { let txs = simulate_da(value_setter_admin_private_key, election_admin_private_key); - let some_sequencer: [u8; 32] = [101; 32]; + let some_sequencer: [u8; 32] = [121; 32]; let apply_blob_outcome = StateTransitionFunction::::apply_blob( &mut demo, &mut new_test_blob(Batch { txs }, &some_sequencer), None, ); - assert!( - matches!(apply_blob_outcome.inner, SequencerOutcome::Ignored), + assert_eq!( + SequencerOutcome::Ignored, + apply_blob_outcome.inner, "Batch should have been skipped due to unknown sequencer" ); diff --git a/module-system/sov-modules-macros/Cargo.toml b/module-system/sov-modules-macros/Cargo.toml index d9c942ac4..f5a1efb7e 100644 --- a/module-system/sov-modules-macros/Cargo.toml +++ b/module-system/sov-modules-macros/Cargo.toml @@ -21,9 +21,9 @@ path = "tests/all_tests.rs" [dev-dependencies] trybuild = "1.0" -sov-modules-api = { path = "../sov-modules-api", version = "0.1" } +sov-modules-api = { path = "../sov-modules-api", version = "0.1", default-features = false } jsonrpsee = { workspace = true, features = ["macros", "http-client", "server"] } -sov-state = { path = "../sov-state", version = "0.1" } +sov-state = { path = "../sov-state", version = "0.1", default-features = false } tempfile = { workspace = true } [dependencies] diff --git a/module-system/sov-modules-macros/tests/derive_rpc.rs b/module-system/sov-modules-macros/tests/derive_rpc.rs index 397218f60..8d9316031 100644 --- a/module-system/sov-modules-macros/tests/derive_rpc.rs +++ b/module-system/sov-modules-macros/tests/derive_rpc.rs @@ -1,8 +1,8 @@ -use sov_modules_api::default_context::DefaultContext; +use sov_modules_api::default_context::ZkDefaultContext; use sov_modules_api::Context; use sov_modules_macros::rpc_gen; use sov_modules_macros::ModuleInfo; -use sov_state::{ProverStorage, WorkingSet}; +use sov_state::{WorkingSet, ZkStorage}; #[derive(ModuleInfo)] pub struct TestStruct { @@ -33,7 +33,7 @@ impl TestStruct { } } -pub struct TestRuntime { +pub struct TestRuntime { test_struct: TestStruct, } @@ -43,29 +43,30 @@ struct RpcStorage { pub storage: C::Storage, } -impl TestStructRpcImpl for RpcStorage { +impl TestStructRpcImpl for RpcStorage { fn get_working_set( &self, - ) -> ::sov_state::WorkingSet<::Storage> { + ) -> ::sov_state::WorkingSet<::Storage> { ::sov_state::WorkingSet::new(self.storage.clone()) } } fn main() { - let tmpdir = tempfile::tempdir().unwrap(); - let native_storage = ProverStorage::with_path(tmpdir.path()).unwrap(); - let r: RpcStorage = RpcStorage { - storage: native_storage.clone(), + let storage = ZkStorage::new([1u8; 32]); + let r: RpcStorage = RpcStorage { + storage: storage.clone(), }; { let result = - as TestStructRpcServer>::first_method(&r); + as TestStructRpcServer>::first_method( + &r, + ); assert_eq!(result.unwrap(), 11); } { let result = - as TestStructRpcServer>::second_method( + as TestStructRpcServer>::second_method( &r, 22, ); assert_eq!(result.unwrap(), 22); @@ -73,7 +74,7 @@ fn main() { { let result = - as TestStructRpcServer>::third_method( + as TestStructRpcServer>::third_method( &r, 33, ); assert_eq!(result.unwrap(), 33); @@ -81,7 +82,7 @@ fn main() { { let result = - as TestStructRpcServer>::fourth_method( + as TestStructRpcServer>::fourth_method( &r, 44, ); assert_eq!(result.unwrap(), 44); @@ -89,7 +90,7 @@ fn main() { { let result = - as TestStructRpcServer>::health(&r); + as TestStructRpcServer>::health(&r); assert_eq!(result.unwrap(), ()); } diff --git a/module-system/sov-modules-macros/tests/dispatch/derive_dispatch.rs b/module-system/sov-modules-macros/tests/dispatch/derive_dispatch.rs index 4e220d395..98c83d0df 100644 --- a/module-system/sov-modules-macros/tests/dispatch/derive_dispatch.rs +++ b/module-system/sov-modules-macros/tests/dispatch/derive_dispatch.rs @@ -2,9 +2,9 @@ mod modules; use modules::{first_test_module, second_test_module}; use sov_modules_api::Address; use sov_modules_api::ModuleInfo; -use sov_modules_api::{default_context::DefaultContext, Context, Genesis}; +use sov_modules_api::{default_context::ZkDefaultContext, Context, Genesis}; use sov_modules_macros::{DefaultRuntime, DispatchCall, Genesis, MessageCodec}; -use sov_state::ProverStorage; +use sov_state::ZkStorage; #[derive(Genesis, DispatchCall, MessageCodec, DefaultRuntime)] #[serialization(borsh::BorshDeserialize, borsh::BorshSerialize)] @@ -15,15 +15,14 @@ struct Runtime { fn main() { use sov_modules_api::DispatchCall; - type RT = Runtime; + type RT = Runtime; let runtime = &mut RT::default(); - let tmpdir = tempfile::tempdir().unwrap(); - let storage = ProverStorage::with_path(tmpdir.path()).unwrap(); + let storage = ZkStorage::new([1u8; 32]); let mut working_set = &mut sov_state::WorkingSet::new(storage); let config = GenesisConfig::new((), ()); runtime.genesis(&config, working_set).unwrap(); - let context = DefaultContext::new(Address::try_from([0; 32].as_ref()).unwrap()); + let context = ZkDefaultContext::new(Address::try_from([0; 32].as_ref()).unwrap()); let value = 11; { diff --git a/module-system/sov-modules-macros/tests/dispatch/derive_genesis.rs b/module-system/sov-modules-macros/tests/dispatch/derive_genesis.rs index 9c25886b2..42c3cba8a 100644 --- a/module-system/sov-modules-macros/tests/dispatch/derive_genesis.rs +++ b/module-system/sov-modules-macros/tests/dispatch/derive_genesis.rs @@ -1,10 +1,10 @@ mod modules; use modules::{first_test_module, second_test_module}; -use sov_modules_api::default_context::DefaultContext; +use sov_modules_api::default_context::ZkDefaultContext; use sov_modules_api::Context; use sov_modules_macros::{DefaultRuntime, DispatchCall, Genesis, MessageCodec}; -use sov_state::ProverStorage; +use sov_state::ZkStorage; // Debugging hint: To expand the macro in tests run: `cargo expand --test tests` #[derive(Genesis, DispatchCall, MessageCodec, DefaultRuntime)] @@ -20,9 +20,8 @@ where fn main() { use sov_modules_api::Genesis; - type C = DefaultContext; - let tmpdir = tempfile::tempdir().unwrap(); - let storage = ProverStorage::with_path(tmpdir.path()).unwrap(); + type C = ZkDefaultContext; + let storage = ZkStorage::new([1u8; 32]); let mut working_set = &mut sov_state::WorkingSet::new(storage); let runtime = &mut Runtime::::default(); let config = GenesisConfig::new((), ()); diff --git a/module-system/sov-modules-macros/tests/module_info/mod_and_state.rs b/module-system/sov-modules-macros/tests/module_info/mod_and_state.rs index d66ee9495..ddf9e5691 100644 --- a/module-system/sov-modules-macros/tests/module_info/mod_and_state.rs +++ b/module-system/sov-modules-macros/tests/module_info/mod_and_state.rs @@ -1,4 +1,4 @@ -use sov_modules_api::default_context::DefaultContext; +use sov_modules_api::default_context::ZkDefaultContext; use sov_modules_api::Context; use sov_modules_macros::ModuleInfo; use sov_state::StateMap; @@ -39,7 +39,7 @@ mod second_test_module { } fn main() { - type C = DefaultContext; + type C = ZkDefaultContext; let second_test_struct = as std::default::Default>::default(); diff --git a/module-system/sov-modules-macros/tests/module_info/parse.rs b/module-system/sov-modules-macros/tests/module_info/parse.rs index c95da7ee2..f271916a7 100644 --- a/module-system/sov-modules-macros/tests/module_info/parse.rs +++ b/module-system/sov-modules-macros/tests/module_info/parse.rs @@ -1,4 +1,4 @@ -use sov_modules_api::default_context::DefaultContext; +use sov_modules_api::default_context::ZkDefaultContext; use sov_modules_api::{Context, ModuleInfo}; use sov_modules_macros::ModuleInfo; use sov_state::{StateMap, StateValue}; @@ -25,7 +25,7 @@ mod test_module { } fn main() { - type C = DefaultContext; + type C = ZkDefaultContext; let test_struct = as std::default::Default>::default(); let prefix1 = test_struct.test_state1.prefix(); diff --git a/module-system/sov-state/Cargo.toml b/module-system/sov-state/Cargo.toml index 46b6275f4..c66779620 100644 --- a/module-system/sov-state/Cargo.toml +++ b/module-system/sov-state/Cargo.toml @@ -12,7 +12,6 @@ readme = "README.md" resolver = "2" [dependencies] - anyhow = { workspace = true } borsh = { workspace = true } serde = { workspace = true }