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. /// Performs initial validation, and returns early if the Wasm is invalid.
/// ///
/// You can control which compiler is used via passing a `Strategy`. /// You can control which compiler is used via passing a `Strategy`.
pub fn instantiate(wasm: &[u8], strategy: Strategy) { pub fn instantiate(wasm: &[u8], known_valid: bool, strategy: Strategy) {
instantiate_with_config(wasm, crate::fuzz_default_config(strategy).unwrap(), None); 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 /// 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. /// The engine will be configured using provided config.
/// ///
/// See also `instantiate` functions. /// 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(); crate::init_fuzzing();
config.interruptable(timeout.is_some()); config.interruptable(timeout.is_some());
@@ -91,7 +101,11 @@ pub fn instantiate_with_config(wasm: &[u8], mut config: Config, timeout: Option<
} }
log_wasm(wasm); 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()); let imports = dummy_imports(&store, module.imports());
match Instance::new(&store, &module, &imports) { match Instance::new(&store, &module, &imports) {

View File

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

View File

@@ -9,5 +9,5 @@ use wasmtime_fuzzing::oracles;
fuzz_target!(|module: ConfiguredModule<SwarmConfig>| { fuzz_target!(|module: ConfiguredModule<SwarmConfig>| {
let mut cfg = wasmtime_fuzzing::fuzz_default_config(Strategy::Auto).unwrap(); let mut cfg = wasmtime_fuzzing::fuzz_default_config(Strategy::Auto).unwrap();
cfg.wasm_multi_memory(true); 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; let mut module = module;
module.ensure_termination(1000); module.ensure_termination(1000);
let wasm_bytes = module.to_bytes(); 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; use wasmtime_fuzzing::oracles;
fuzz_target!(|data: &[u8]| { 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] #[test]
fn instantiate_empty_module() { fn instantiate_empty_module() {
let data = wat::parse_str(include_str!("./fuzzing/empty.wat")).unwrap(); let data = wat::parse_str(include_str!("./fuzzing/empty.wat")).unwrap();
oracles::instantiate(&data, Strategy::Auto); oracles::instantiate(&data, true, Strategy::Auto);
} }
#[test] #[test]
fn instantiate_empty_module_with_memory() { fn instantiate_empty_module_with_memory() {
let data = wat::parse_str(include_str!("./fuzzing/empty_with_memory.wat")).unwrap(); 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] #[test]
@@ -26,5 +26,5 @@ fn instantiate_module_that_compiled_to_x64_has_register_32() {
let mut config = Config::new(); let mut config = Config::new();
config.debug_info(true); config.debug_info(true);
let data = wat::parse_str(include_str!("./fuzzing/issue694.wat")).unwrap(); 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);
} }