ruff/fuzz/fuzz_targets/ruff_fix_validity.rs

27 lines
964 B
Rust

//! Fuzzer harness which actively tries to find testcases that cause Ruff to introduce errors into
//! the resulting file.
#![no_main]
use libfuzzer_sys::{fuzz_target, Corpus};
use ruff::settings::Settings;
use std::sync::OnceLock;
static SETTINGS: OnceLock<Settings> = OnceLock::new();
fn do_fuzz(case: &[u8]) -> Corpus {
// throw away inputs which aren't utf-8
let Ok(code) = std::str::from_utf8(case) else { return Corpus::Reject; };
// the settings are immutable to test_snippet, so we avoid re-initialising here
let settings = SETTINGS.get_or_init(Settings::default);
ruff::test::set_max_iterations(usize::MAX);
// unlike in the test framework, where the number of iterations is well-defined, we are only
// looking for situations where a fix is bad; thus, we set the iterations to "infinite"
let _ = ruff::test::test_snippet(code, settings);
Corpus::Keep
}
fuzz_target!(|case: &[u8]| -> Corpus { do_fuzz(case) });