mirror of
https://github.com/fluencelabs/parity-wasm
synced 2025-06-29 22:51:56 +00:00
Fix wasm tests
This commit is contained in:
@ -113,4 +113,8 @@ impl ProgramInstance {
|
||||
pub fn store(&self) -> &Store {
|
||||
&self.store
|
||||
}
|
||||
|
||||
pub fn module(&self, name: &str) -> Option<ModuleId> {
|
||||
self.modules.get(name).cloned()
|
||||
}
|
||||
}
|
||||
|
@ -1,6 +1,6 @@
|
||||
mod basics;
|
||||
mod wabt;
|
||||
// mod wasm;
|
||||
mod wasm;
|
||||
|
||||
mod utils {
|
||||
use elements::{Internal, ExportEntry, InitExpr, Opcode, ValueType, GlobalType, GlobalEntry};
|
||||
|
@ -2,7 +2,7 @@ use elements::deserialize_file;
|
||||
use elements::Module;
|
||||
use interpreter::ExecutionParams;
|
||||
use interpreter::value::RuntimeValue;
|
||||
use interpreter::module::{ModuleInstanceInterface, ItemIndex};
|
||||
use interpreter::module::{ItemIndex};
|
||||
use super::utils::program_with_default_env;
|
||||
|
||||
#[test]
|
||||
@ -12,7 +12,7 @@ fn interpreter_inc_i32() {
|
||||
// The WASM file containing the module and function
|
||||
const WASM_FILE: &str = &"res/cases/v1/inc_i32.wasm";
|
||||
|
||||
let program = program_with_default_env();
|
||||
let mut program = program_with_default_env();
|
||||
|
||||
let module: Module =
|
||||
deserialize_file(WASM_FILE).expect("Failed to deserialize module from buffer");
|
||||
@ -20,17 +20,13 @@ fn interpreter_inc_i32() {
|
||||
// the functions expects a single i32 parameter
|
||||
let args = vec![RuntimeValue::I32(i32_val)];
|
||||
let exp_retval = Some(RuntimeValue::I32(i32_val + 1));
|
||||
let execution_params = ExecutionParams::from(args);
|
||||
|
||||
let module_result = program
|
||||
.add_module("main", module, None);
|
||||
let module_result = program.add_module("main", module, &mut ());
|
||||
|
||||
let module = module_result
|
||||
.expect("Failed to initialize module");
|
||||
|
||||
let retval = module
|
||||
.execute_export(FUNCTION_NAME, execution_params)
|
||||
.expect("");
|
||||
let retval = program.invoke_export("main", FUNCTION_NAME, args, &mut ()).expect("");
|
||||
assert_eq!(exp_retval, retval);
|
||||
}
|
||||
|
||||
@ -43,29 +39,26 @@ fn interpreter_accumulate_u8() {
|
||||
// The octet sequence being accumulated
|
||||
const BUF: &[u8] = &[9,8,7,6,5,4,3,2,1];
|
||||
|
||||
let program = program_with_default_env();
|
||||
let mut program = program_with_default_env();
|
||||
|
||||
// Load the module-structure from wasm-file and add to program
|
||||
let module: Module =
|
||||
deserialize_file(WASM_FILE).expect("Failed to deserialize module from buffer");
|
||||
let module = program
|
||||
.add_module("main", module, None)
|
||||
.add_module("main", module, &mut ())
|
||||
.expect("Failed to initialize module");
|
||||
|
||||
// => env module is created
|
||||
let env_instance = program.module("env").unwrap();
|
||||
// => linear memory is created
|
||||
let env_memory = env_instance.memory(ItemIndex::Internal(0)).unwrap();
|
||||
let env_module = program.module("env").unwrap();
|
||||
let env_memory = env_module.memory_by_index(program.store(), 0).unwrap();
|
||||
|
||||
// Place the octet-sequence at index 0 in linear memory
|
||||
let offset: u32 = 0;
|
||||
let _ = env_memory.set(offset, BUF);
|
||||
let _ = env_memory.resolve(program.store()).set(offset, BUF);
|
||||
|
||||
// Set up the function argument list and invoke the function
|
||||
let args = vec![RuntimeValue::I32(BUF.len() as i32), RuntimeValue::I32(offset as i32)];
|
||||
let execution_params = ExecutionParams::from(args);
|
||||
let retval = module
|
||||
.execute_export(FUNCTION_NAME, execution_params)
|
||||
let retval = program
|
||||
.invoke_export("main", FUNCTION_NAME, args, &mut ())
|
||||
.expect("Failed to execute function");
|
||||
|
||||
// For verification, repeat accumulation using native code
|
||||
|
Reference in New Issue
Block a user