This is enough to get an `externref -> externref` identity function passing. However, `externref`s that are dropped by compiled Wasm code are (safely) leaked. Follow up work will leverage cranelift's stack maps to resolve this issue.
14 lines
350 B
Rust
14 lines
350 B
Rust
use wasmtime::*;
|
|
|
|
#[test]
|
|
fn get_none() {
|
|
let store = Store::default();
|
|
let ty = TableType::new(ValType::FuncRef, Limits::new(1, None));
|
|
let table = Table::new(&store, ty, Val::ExternRef(None)).unwrap();
|
|
match table.get(0) {
|
|
Some(Val::ExternRef(None)) => {}
|
|
_ => panic!(),
|
|
}
|
|
assert!(table.get(1).is_none());
|
|
}
|