mirror of https://github.com/google/oss-fuzz.git
f858510cbe
* example project: fix minor problems with standalone fuzzer * typo: "successfull" -> "successful" * main should explicitly return 0 on success * example project: fix minor problems with Makefile * make "all" the first target * use LIB_FUZZING_ENGINE to reference fuzzer in all places * example project: fix typos in README * Add upstream qpdf maintainer as auto_cc for qpdf I am adding myself (using my Google account) as an auto_cc in preparation for taking over ownership of the qpdf project and doing a full integration with oss-fuzz. |
||
---|---|---|
.. | ||
do_stuff_test_data | ||
Makefile | ||
README.md | ||
do_stuff_fuzzer.cpp | ||
do_stuff_fuzzer.dict | ||
do_stuff_unittest.cpp | ||
my_api.cpp | ||
my_api.h | ||
standalone_fuzz_target_runner.cpp |
README.md
Example of OSS-Fuzz ideal integration.
This directory contains an example software project that has most of the traits of ideal support for fuzzing.
Files in my-api-repo
Imagine that these files reside in your project's repository:
- my_api.h: and my_api.cpp implement the API we want to test/fuzz. The function
DoStuff()
inside my_api.cpp contains a bug. (Find it!) - do_stuff_unittest.cpp: is a unit test for
DoStuff()
. Unit tests are not necessary for fuzzing but are generally a good practice. - do_stuff_fuzzer.cpp: is a fuzz target for
DoStuff()
. - do_stuff_test_data: corpus directory for do_stuff_fuzzer.cpp.
- do_stuff_fuzzer.dict: a fuzzing dictionary file for
DoStuff()
. Optional, but may improve fuzzing in many cases. - Makefile: is a build file (the same can be done with other build systems):
- accepts external compiler flags via
$CC
,$CXX
,$CFLAGS
,$CXXFLAGS
- accepts external fuzzing engine via
$LIB_FUZZING_ENGINE
, by default uses standalone_fuzz_target_runner.cpp - builds the fuzz target(s) and their corpus archive(s)
make check
executes do_stuff_fuzzer.cpp ondo_stuff_test_data/*
, thus ensures that the fuzz target is up to date and uses it as a regression test.
- accepts external compiler flags via
- standalone_fuzz_target_runner.cpp: is a simple standalone runner for fuzz targets. You may use it to execute a fuzz target on given files w/o having to link in libFuzzer or other fuzzing engine.
Files in OSS-Fuzz repository
- oss-fuzz/projects/example
- Dockerfile: sets up the build environment
- build.sh: builds the fuzz target(s). The smaller this file the better (most of the logic should be inside the project's build system).
- project.yaml: short project description and contact info.
Example bug
Example bug report filed automatically: https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=1562