Clone this repo:

Branches

  1. 0eca37f [experimental] Move js_in_process_fuzzer crash to run in all builds by Tigran Bantikyan · 3 hours ago main
  2. 00dd6c8 [Fuzzing] Remove icu_assets from fuzzer_test template by Edgar Aguilar · 2 days ago
  3. 35e6df0 Busybody: Format GN files by Kalvin Lee · 2 days ago
  4. 2ae6e67 [Fuzzing] Fix V8 snapshot and ICU initialization on Android by Edgar Aguilar · 2 days ago
  5. 3167aff libfuzzer: Remove inactive reviewer by Giovanni Ortuño Urquidi · 3 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