37 releases

0.12.0 Feb 20, 2024
0.11.2 Feb 13, 2023
0.11.1 Oct 25, 2022
0.11.0 Sep 27, 2021
0.4.0 Mar 30, 2017

#44 in Testing

Download history 4770/week @ 2023-12-22 5331/week @ 2023-12-29 7709/week @ 2024-01-05 7927/week @ 2024-01-12 7590/week @ 2024-01-19 8643/week @ 2024-01-26 7573/week @ 2024-02-02 6944/week @ 2024-02-09 8897/week @ 2024-02-16 8286/week @ 2024-02-23 7000/week @ 2024-03-01 9109/week @ 2024-03-08 8254/week @ 2024-03-15 7823/week @ 2024-03-22 8178/week @ 2024-03-29 7260/week @ 2024-04-05

33,081 downloads per month
Used in text_manipulation_rs

MIT/Apache

64KB
1.5K SLoC

cargo fuzz

A cargo subcommand for fuzzing with libFuzzer! Easy to use!

Installation

$ cargo install cargo-fuzz

Note: libFuzzer needs LLVM sanitizer support, so this only works on x86-64 Linux, x86-64 macOS and Apple-Silicon (aarch64) macOS for now. You'll also need a C++ compiler with C++11 support.

If you have an old version of cargo fuzz, you can upgrade with this command:

$ cargo install -f cargo-fuzz

Usage

cargo fuzz init

Initialize a cargo fuzz project for your crate!

If your crate uses cargo workspaces, add fuzz directory to workspace.members in root Cargo.toml

fuzz directory can be either a part of an existing workspace (default) or use an independent workspace. If latter is desired, you can use cargo fuzz init --fuzzing-workspace=true.

cargo fuzz add <target>

Create a new fuzzing target!

cargo fuzz run <target>

Run a fuzzing target and find bugs!

cargo fuzz fmt <target> <input>

Print the std::fmt::Debug output for a test case. Useful when your fuzz target takes an Arbitrary input!

cargo fuzz tmin <target> <input>

Found a failing input? Minify it to the smallest input that causes that failure for easier debugging!

cargo fuzz cmin <target>

Minify your corpus of input files!

cargo fuzz coverage <target>

Generate coverage information on the fuzzed program!

Documentation

Documentation can be found in the Rust Fuzz Book.

You can also always find the full command-line options that are available with --help:

$ cargo fuzz --help

Trophy case

The trophy case has a list of bugs found by cargo fuzz (and others). Did cargo fuzz and libFuzzer find a bug for you? Add it to the trophy case!

License

cargo-fuzz is distributed under the terms of both the MIT license and the Apache License (Version 2.0).

See LICENSE-APACHE and LICENSE-MIT for details.

Dependencies

~4–15MB
~175K SLoC