# Copyright 2015 The Chromium Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. # LibFuzzer is a LLVM tool for coverage-guided fuzz testing. # See http://www.chromium.org/developers/testing/libfuzzer # # To enable libfuzzer, 'use_libfuzzer' GN option should be set to true. # Or to enable afl, 'use_afl' GN option should be set to true. import("//build/config/features.gni") import("//build/config/sanitizers/sanitizers.gni") source_set("libfuzzer_main") { deps = [] sources = [] if (use_libfuzzer) { deps += [ "//third_party/libFuzzer:libfuzzer" ] } else if (use_afl) { deps += [ "//third_party/libFuzzer:afl_driver" ] } else if (use_drfuzz) { sources += [ "drfuzz_main.cc" ] } else { sources += [ "unittest_main.cc" ] } } # A config used by all fuzzer_tests. config("fuzzer_test_config") { if (use_libfuzzer && is_mac) { ldflags = [ "-Wl,-U,_LLVMFuzzerCustomMutator", "-Wl,-U,_LLVMFuzzerInitialize", ] } } # Noop config used to tag fuzzer tests excluded from clusterfuzz. # Libfuzzer build bot uses this to filter out targets while # building an archive for clusterfuzz. config("no_clusterfuzz") { } # noop to tag seed corpus rules. source_set("seed_corpus") { }