From 90dee6b31c1ea91b648f8bb54eec988428294422 Mon Sep 17 00:00:00 2001 From: Samuel Moelius Date: Sun, 7 Jul 2024 15:24:17 +0000 Subject: [PATCH] Enable `AFL_SHA1_FILENAMES` by default --- README.md | 6 ++++++ cargo-test-fuzz/Cargo.toml | 2 ++ cargo-test-fuzz/src/lib.rs | 3 +++ 3 files changed, 11 insertions(+) diff --git a/README.md b/README.md index 3fc5fb17..9d30ff20 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,9 @@ # test-fuzz +**News:** `cargo-test-fuzz` 5.3.0 enables [`AFL_SHA1_FILENAMES`] by default. If this causes you problems, please [open an issue], and reinstall `cargo-test-fuzz` with `--no-default-features`. + +--- + `test-fuzz` is a Cargo subcommand and a collection of Rust macros to automate certain tasks related to fuzzing with [`afl.rs`], including: - generating a fuzzing corpus @@ -512,6 +516,7 @@ These options are incompatible in the following sense. If a fuzz target's argume [Substrate externalities]: https://substrate.dev/docs/en/knowledgebase/runtime/tests#mock-runtime-storage [The Cargo Book]: https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#choosing-features [Tips and tricks]: #tips-and-tricks +[`AFL_SHA1_FILENAMES`]: https://github.com/AFLplusplus/AFLplusplus/blob/stable/docs/env_variables.md [`Clone`]: https://doc.rust-lang.org/std/clone/trait.Clone.html [`Path`]: https://doc.rust-lang.org/std/path/struct.Path.html [`TEST_FUZZ_MANIFEST_PATH`]: #test_fuzz_manifest_path @@ -549,5 +554,6 @@ These options are incompatible in the following sense. If a fuzz target's argume [conversion.rs]: https://github.com/trailofbits/test-fuzz/blob/master/examples/tests/conversion.rs#L5 [deriving them]: https://serde.rs/derive.html [is not enabled]: https://github.com/rust-lang/rust/issues/45599#issuecomment-460488107 +[open an issue]: https://github.com/trailofbits/test-fuzz/issues [patch]: https://doc.rust-lang.org/edition-guide/rust-2018/cargo-and-crates-io/replacing-dependencies-with-patch.html [won't allow you to]: https://doc.rust-lang.org/book/ch19-03-advanced-traits.html#using-the-newtype-pattern-to-implement-external-traits-on-external-types diff --git a/cargo-test-fuzz/Cargo.toml b/cargo-test-fuzz/Cargo.toml index 0665b606..dcef2bb7 100644 --- a/cargo-test-fuzz/Cargo.toml +++ b/cargo-test-fuzz/Cargo.toml @@ -50,6 +50,8 @@ xshell = { workspace = true } testing = { workspace = true } [features] +default = ["sha1-filenames"] +sha1-filenames = [] test-install = [] [lints] diff --git a/cargo-test-fuzz/src/lib.rs b/cargo-test-fuzz/src/lib.rs index 8c2a1860..29a623d1 100644 --- a/cargo-test-fuzz/src/lib.rs +++ b/cargo-test-fuzz/src/lib.rs @@ -1153,6 +1153,9 @@ fn fuzz_command( if opts.run_until_crash { envs.push(("AFL_BENCH_UNTIL_CRASH", "1")); } + if cfg!(feature = "sha1-filenames") { + envs.push(("AFL_SHA1_FILENAMES", "1")); + } // smoelius: Passing `-c-` disables the cmplog fork server. Use of cmplog with a target that // spawns subprocesses (like libtest does) can leave orphan processes running. This can cause