Update the *.wast runner to use the wasmtime API (#690)
* Update the `*.wast` runner to use the `wasmtime` API This commit migrates the `wasmtime-wast` crate, which executes `*.wast` test suites, to use the `wasmtime` crate exclusively instead of the raw support provided by the `wasmtime-*` family of crates. The primary motivation for this change is to use `*.wast` test to test the support for interface types, but interface types is only being added in the `wasmtime` crate for now rather than all throughout the core crates. This means that without this transition it's much more difficult to write tests for wasm interface types! A secondary motivation for this is that it's testing the support we provide to users through the `wasmtime` crate, since that's the expectation of what most users would use rather than the raw `wasmtime-*` crates. * Run rustfmt * Fix the multi example * Handle v128 values in the `wasmtime` crate Ensure that we allocate 128-bit stack slots instead of 64-bit stack slots. * Update to master * Add comment
This commit is contained in:
@@ -1,7 +1,8 @@
|
||||
use std::path::Path;
|
||||
use wasmtime::{Config, Engine, HostRef, Store};
|
||||
use wasmtime_environ::settings;
|
||||
use wasmtime_environ::settings::Configurable;
|
||||
use wasmtime_environ::{isa, settings};
|
||||
use wasmtime_jit::{native, CompilationStrategy, Compiler, Features};
|
||||
use wasmtime_jit::{CompilationStrategy, Features};
|
||||
use wasmtime_wast::WastContext;
|
||||
|
||||
include!(concat!(env!("OUT_DIR"), "/wast_testsuite_tests.rs"));
|
||||
@@ -11,26 +12,24 @@ include!(concat!(env!("OUT_DIR"), "/wast_testsuite_tests.rs"));
|
||||
// to compile it.
|
||||
fn run_wast(wast: &str, strategy: CompilationStrategy) -> anyhow::Result<()> {
|
||||
let wast = Path::new(wast);
|
||||
let isa = native_isa();
|
||||
let compiler = Compiler::new(isa, strategy);
|
||||
let features = Features {
|
||||
simd: wast.iter().any(|s| s == "simd"),
|
||||
multi_value: wast.iter().any(|s| s == "multi-value"),
|
||||
..Default::default()
|
||||
};
|
||||
let mut wast_context = WastContext::new(Box::new(compiler)).with_features(features);
|
||||
wast_context.register_spectest()?;
|
||||
wast_context.run_file(wast)?;
|
||||
Ok(())
|
||||
}
|
||||
|
||||
fn native_isa() -> Box<dyn isa::TargetIsa> {
|
||||
let mut flag_builder = settings::builder();
|
||||
flag_builder.enable("enable_verifier").unwrap();
|
||||
flag_builder.enable("avoid_div_traps").unwrap();
|
||||
flag_builder.enable("enable_simd").unwrap();
|
||||
|
||||
let isa_builder = native::builder();
|
||||
|
||||
isa_builder.finish(settings::Flags::new(flag_builder))
|
||||
let mut cfg = Config::new();
|
||||
cfg.strategy(strategy)
|
||||
.flags(settings::Flags::new(flag_builder))
|
||||
.features(features);
|
||||
let store = HostRef::new(Store::new(&HostRef::new(Engine::new(&cfg))));
|
||||
let mut wast_context = WastContext::new(store);
|
||||
wast_context.register_spectest()?;
|
||||
wast_context.run_file(wast)?;
|
||||
Ok(())
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user