Merge pull request #2506 from alexcrichton/fix-expect-valid

Fix fuzzer expectation about valid modules
This commit is contained in:
Nick Fitzgerald
2020-12-14 09:53:01 -08:00
committed by GitHub
6 changed files with 25 additions and 10 deletions

View File

@@ -57,8 +57,13 @@ fn log_wat(wat: &str) {
/// Performs initial validation, and returns early if the Wasm is invalid.
///
/// You can control which compiler is used via passing a `Strategy`.
pub fn instantiate(wasm: &[u8], strategy: Strategy) {
instantiate_with_config(wasm, crate::fuzz_default_config(strategy).unwrap(), None);
pub fn instantiate(wasm: &[u8], known_valid: bool, strategy: Strategy) {
instantiate_with_config(
wasm,
known_valid,
crate::fuzz_default_config(strategy).unwrap(),
None,
);
}
/// Instantiate the Wasm buffer, and implicitly fail if we have an unexpected
@@ -67,7 +72,12 @@ pub fn instantiate(wasm: &[u8], strategy: Strategy) {
/// The engine will be configured using provided config.
///
/// See also `instantiate` functions.
pub fn instantiate_with_config(wasm: &[u8], mut config: Config, timeout: Option<Duration>) {
pub fn instantiate_with_config(
wasm: &[u8],
known_valid: bool,
mut config: Config,
timeout: Option<Duration>,
) {
crate::init_fuzzing();
config.interruptable(timeout.is_some());
@@ -91,7 +101,11 @@ pub fn instantiate_with_config(wasm: &[u8], mut config: Config, timeout: Option<
}
log_wasm(wasm);
let module = Module::new(&engine, wasm).unwrap();
let module = match Module::new(&engine, wasm) {
Ok(module) => module,
Err(_) if !known_valid => return,
Err(e) => panic!("failed to compile module: {:?}", e),
};
let imports = dummy_imports(&store, module.imports());
match Instance::new(&store, &module, &imports) {

View File

@@ -9,6 +9,7 @@ use wasmtime_fuzzing::oracles;
fuzz_target!(|module: MaybeInvalidModule| {
oracles::instantiate_with_config(
&module.to_bytes(),
false,
wasmtime_fuzzing::fuzz_default_config(Strategy::Auto).unwrap(),
Some(Duration::from_secs(20)),
);

View File

@@ -9,5 +9,5 @@ use wasmtime_fuzzing::oracles;
fuzz_target!(|module: ConfiguredModule<SwarmConfig>| {
let mut cfg = wasmtime_fuzzing::fuzz_default_config(Strategy::Auto).unwrap();
cfg.wasm_multi_memory(true);
oracles::instantiate_with_config(&module.to_bytes(), cfg, Some(Duration::from_secs(20)));
oracles::instantiate_with_config(&module.to_bytes(), true, cfg, Some(Duration::from_secs(20)));
});

View File

@@ -9,5 +9,5 @@ fuzz_target!(|module: Module| {
let mut module = module;
module.ensure_termination(1000);
let wasm_bytes = module.to_bytes();
oracles::instantiate(&wasm_bytes, Strategy::Auto);
oracles::instantiate(&wasm_bytes, true, Strategy::Auto);
});

View File

@@ -5,5 +5,5 @@ use wasmtime::Strategy;
use wasmtime_fuzzing::oracles;
fuzz_target!(|data: &[u8]| {
oracles::instantiate(data, Strategy::Auto);
oracles::instantiate(data, false, Strategy::Auto);
});

View File

@@ -11,13 +11,13 @@ use wasmtime_fuzzing::oracles;
#[test]
fn instantiate_empty_module() {
let data = wat::parse_str(include_str!("./fuzzing/empty.wat")).unwrap();
oracles::instantiate(&data, Strategy::Auto);
oracles::instantiate(&data, true, Strategy::Auto);
}
#[test]
fn instantiate_empty_module_with_memory() {
let data = wat::parse_str(include_str!("./fuzzing/empty_with_memory.wat")).unwrap();
oracles::instantiate(&data, Strategy::Auto);
oracles::instantiate(&data, true, Strategy::Auto);
}
#[test]
@@ -26,5 +26,5 @@ fn instantiate_module_that_compiled_to_x64_has_register_32() {
let mut config = Config::new();
config.debug_info(true);
let data = wat::parse_str(include_str!("./fuzzing/issue694.wat")).unwrap();
oracles::instantiate_with_config(&data, config, None);
oracles::instantiate_with_config(&data, true, config, None);
}