2019-08-07 14:37:16 +00:00
|
|
|
---
|
|
|
|
layout: default
|
|
|
|
title: ClusterFuzz
|
2019-08-21 22:10:15 +00:00
|
|
|
parent: Further reading
|
2019-08-07 14:37:16 +00:00
|
|
|
nav_order: 1
|
2019-08-21 22:10:15 +00:00
|
|
|
permalink: /further-reading/clusterfuzz/
|
2019-08-07 14:37:16 +00:00
|
|
|
---
|
|
|
|
|
|
|
|
# ClusterFuzz
|
|
|
|
|
|
|
|
[ClusterFuzz](https://github.com/google/clusterfuzz) is the distributed fuzzing
|
|
|
|
infrastructure behind OSS-Fuzz. It was initially built for fuzzing Chrome at
|
|
|
|
scale.
|
|
|
|
|
|
|
|
- TOC
|
|
|
|
{:toc}
|
|
|
|
---
|
|
|
|
|
|
|
|
## Web interface
|
|
|
|
|
|
|
|
ClusterFuzz provides a [web interface](https://oss-fuzz.com)
|
|
|
|
to view statistics about your fuzz targets, as well as current crashes.
|
|
|
|
|
|
|
|
*Note*: Access is restricted to project developers who we auto CC on new bug
|
|
|
|
reports.
|
|
|
|
|
|
|
|
## Testcase reports
|
|
|
|
|
|
|
|
ClusterFuzz will automatically de-duplicate and file reproducible crashes into
|
|
|
|
our [bug tracker](https://bugs.chromium.org/p/oss-fuzz/issues/list). We provide
|
|
|
|
a crash report page that gives you the stack trace, a link to the crashing
|
|
|
|
testcase, and regression ranges where the bug was most likely introduced.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4d44a/4d44a9ed4633f3b9984dbdfb9e2b2fd59f62b7f8" alt="report"
|
|
|
|
|
|
|
|
## Fuzzer stats
|
|
|
|
|
|
|
|
You can view statistics about your fuzz targets (e.g. speed, coverage
|
|
|
|
information, memory usage) on our fuzzer statistics dashboard.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c3af2/c3af2c24e27606ce5e442224ed2bca95827553ed" alt="stats"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/34090/340904c250659afc6587ab976a15df4ba290ab49" alt="stats"
|
|
|
|
|
|
|
|
## Coverage reports
|
|
|
|
|
|
|
|
We provide coverage reports, where we highlight the parts of source code that
|
|
|
|
are being reached by your fuzz target. Make sure to look at the uncovered code
|
2021-04-20 22:46:16 +00:00
|
|
|
marked in red and add appropriate fuzz targets to cover those use cases.
|
2019-08-07 14:37:16 +00:00
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/76c37/76c37cf1a79737aaff86264d7226663bd6b7afe4" alt="coverage_1"
|
|
|
|
data:image/s3,"s3://crabby-images/2eb30/2eb308c3039cc1bade1d8dc006d52cd569d39aaa" alt="coverage_2"
|
|
|
|
|
|
|
|
## Performance analyzer
|
|
|
|
|
|
|
|
You can view performance issues that your fuzz target is running into (e.g.
|
|
|
|
leaks, timeouts, etc) by clicking on `Performance` link on our fuzzer statistics
|
|
|
|
dashboard. Make sure to fix all cited issues, so as to keep your fuzz target
|
|
|
|
running efficiently and finding new bugs.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c74ae/c74aed4457226f3ce10a37b204dc304dc9a75a6f" alt="performance_analyzer"
|
|
|
|
|
|
|
|
## Crash stats
|
|
|
|
|
|
|
|
You can view statistics of crashes over time on our crash statistics dashboard.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ac0e4/ac0e48d309c042be634bae1b5a45c1b01f360e9f" alt="crash_stats"
|