Fix wasm tests

This commit is contained in:
Sergey Pepyakin
2017-12-12 15:40:54 +01:00
parent 4297a64e9e
commit c5c8af03e1
3 changed files with 16 additions and 19 deletions

View File

@ -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()
}
}

View File

@ -1,6 +1,6 @@
mod basics;
mod wabt;
// mod wasm;
mod wasm;
mod utils {
use elements::{Internal, ExportEntry, InitExpr, Opcode, ValueType, GlobalType, GlobalEntry};

View File

@ -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