Clone this repo:

Branches

  1. 36fbe57 [Fuzzing] Fix CommandLine init in template_url fuzzer by Edgar Aguilar · 2 days ago main
  2. 7d6f66e [experimental] Add crash to Fuzzilli fuzzing to investigate ClusterFuzz by Tigran Bantikyan · 2 days ago
  3. 42ad7d0 Add additionalOptionsBags definition in MojoLockManagerProfile.swift by Tigran Bantikyan · 3 days ago
  4. 9f43e5b Reland "[Fuzzing] Fix ICU initialization." by Edgar Aguilar · 4 days ago
  5. 003b352 [fuzzing] Add experimental Fuzzilli profile for Mojo CredentialManager by Tigran Bantikyan · 4 days ago

Fuzzing in Chromium

go/chrome-fuzzing

Just got a bug report from ClusterFuzz?: If you want to reproduce a ClusterFuzz crash locally, see How to Reproduce a Crash from ClusterFuzz.

Fuzzing is an automated software testing technique that provides invalid, unexpected, or random data as inputs to a program to find bugs.

Why fuzz? Fuzzing finds thousands of security and stability issues before they reach users (see go/fuzzing-success). For more information about the benefits of fuzzing, see go/why-fuzz.

Where to fuzz? Fuzz code that parses, decodes, or manipulates input from untrusted sources, such as the web.

Getting started

In Chromium, you can create and submit fuzz targets that run continuously at scale on ClusterFuzz. Prefer FuzzTest for all new fuzz targets. Use libFuzzer only to maintain existing targets.

FuzzTest (recommended)

FuzzTest integrates with the gtest framework and tests code that accepts structured, typed inputs, such as int, std::string, std::vector, or custom classes.

libFuzzer (deprecated)

libFuzzer tests APIs that consume raw byte buffers, such as image decoders and JSON or XML parsers.

Advanced topics

Getting help

If you have questions or encounter issues,

  • email chrome-fuzzing-core@google.com or
  • file a bug using the Chrome > Security > Fuzzing component.

View dashboard and stats