From ed9a5b226c85a68a238f792cea92f98a448a705a Mon Sep 17 00:00:00 2001 From: clearloop <26088946+clearloop@users.noreply.github.com> Date: Wed, 15 Nov 2023 05:00:38 +0800 Subject: [PATCH] chore(wasm-instrument): move syscall table test to core-backend (#3460) --- Cargo.lock | 1 - core-backend/src/tests.rs | 59 ++++++++++++++++++++++++++++++ utils/wasm-instrument/Cargo.toml | 2 - utils/wasm-instrument/src/lib.rs | 6 +-- utils/wasm-instrument/src/tests.rs | 55 ---------------------------- 5 files changed, 62 insertions(+), 61 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 6abe19f1120..5923bdde02d 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -4505,7 +4505,6 @@ version = "1.0.2" dependencies = [ "enum-iterator 1.4.1", "gear-core", - "gear-core-backend", "gwasm-instrument", "wasmparser-nostd 0.100.1", "wat", diff --git a/core-backend/src/tests.rs b/core-backend/src/tests.rs index f2ca2f96de9..54753a30ce1 100644 --- a/core-backend/src/tests.rs +++ b/core-backend/src/tests.rs @@ -595,3 +595,62 @@ fn test_register_write_as_with_zero_size() { core::mem::size_of::() as u32 ); } + +/// Check that all sys calls are supported by backend. +#[test] +fn test_sys_calls_table() { + use crate::{ + env::{BackendReport, Environment}, + error::ActorTerminationReason, + mock::MockExt, + }; + use gear_core::message::DispatchKind; + use gear_wasm_instrument::{ + gas_metering::ConstantCostRules, + inject, + parity_wasm::{self, builder}, + SysCallName, + }; + + // Make module with one empty function. + let mut module = builder::module() + .function() + .signature() + .build() + .build() + .build(); + + // Insert syscalls imports. + for name in SysCallName::instrumentable() { + let sign = name.signature(); + let types = module.type_section_mut().unwrap().types_mut(); + let type_no = types.len() as u32; + types.push(parity_wasm::elements::Type::Function(sign.func_type())); + + module = builder::from_module(module) + .import() + .module("env") + .external() + .func(type_no) + .field(name.to_str()) + .build() + .build(); + } + + let module = inject(module, &ConstantCostRules::default(), "env").unwrap(); + let code = module.into_bytes().unwrap(); + + // Execute wasm and check success. + let ext = MockExt::default(); + let env = + Environment::new(ext, &code, DispatchKind::Init, Default::default(), 0.into()).unwrap(); + let report = env + .execute(|_, _, _| -> Result<(), u32> { Ok(()) }) + .unwrap(); + + let BackendReport { + termination_reason, .. + } = report; + + assert_eq!(termination_reason, ActorTerminationReason::Success.into()); +} diff --git a/utils/wasm-instrument/Cargo.toml b/utils/wasm-instrument/Cargo.toml index c79f9f48507..e6a304b5a8b 100644 --- a/utils/wasm-instrument/Cargo.toml +++ b/utils/wasm-instrument/Cargo.toml @@ -17,12 +17,10 @@ enum-iterator.workspace = true [dev-dependencies] wasmparser.workspace = true wat.workspace = true -gear-core-backend = { workspace = true, features = ["mock"] } gear-core.workspace = true [features] default = ["std"] std = [ - "gear-core-backend/std", "gwasm-instrument/std", ] diff --git a/utils/wasm-instrument/src/lib.rs b/utils/wasm-instrument/src/lib.rs index fe38b421e86..b98bdc01d4e 100644 --- a/utils/wasm-instrument/src/lib.rs +++ b/utils/wasm-instrument/src/lib.rs @@ -24,15 +24,15 @@ extern crate alloc; use alloc::vec; use gwasm_instrument::{ - gas_metering::{self, Rules}, + gas_metering::Rules, parity_wasm::{ builder, elements::{self, BlockType, ImportCountType, Instruction, Instructions, Local, ValueType}, }, }; -use crate::syscalls::SysCallName; -pub use gwasm_instrument::{self as wasm_instrument, parity_wasm}; +pub use crate::syscalls::SysCallName; +pub use gwasm_instrument::{self as wasm_instrument, gas_metering, parity_wasm}; #[cfg(test)] mod tests; diff --git a/utils/wasm-instrument/src/tests.rs b/utils/wasm-instrument/src/tests.rs index d85a139fcca..f44ddd8ea1b 100644 --- a/utils/wasm-instrument/src/tests.rs +++ b/utils/wasm-instrument/src/tests.rs @@ -618,61 +618,6 @@ test_gas_counter_injection! { "# } -/// Check that all sys calls are supported by backend. -#[test] -fn test_sys_calls_table() { - use gas_metering::ConstantCostRules; - use gear_core::message::DispatchKind; - use gear_core_backend::{ - env::{BackendReport, Environment}, - error::ActorTerminationReason, - mock::MockExt, - }; - use parity_wasm::builder; - - // Make module with one empty function. - let mut module = builder::module() - .function() - .signature() - .build() - .build() - .build(); - - // Insert syscalls imports. - for name in SysCallName::instrumentable() { - let sign = name.signature(); - let types = module.type_section_mut().unwrap().types_mut(); - let type_no = types.len() as u32; - types.push(parity_wasm::elements::Type::Function(sign.func_type())); - - module = builder::from_module(module) - .import() - .module("env") - .external() - .func(type_no) - .field(name.to_str()) - .build() - .build(); - } - - let module = inject(module, &ConstantCostRules::default(), "env").unwrap(); - let code = module.into_bytes().unwrap(); - - // Execute wasm and check success. - let ext = MockExt::default(); - let env = - Environment::new(ext, &code, DispatchKind::Init, Default::default(), 0.into()).unwrap(); - let report = env - .execute(|_, _, _| -> Result<(), u32> { Ok(()) }) - .unwrap(); - - let BackendReport { - termination_reason, .. - } = report; - - assert_eq!(termination_reason, ActorTerminationReason::Success.into()); -} - #[test] fn check_memory_array_pointers_definition_correctness() { let sys_calls = SysCallName::instrumentable();