| Index: testing/libfuzzer/fuzzers/template_url_parser_fuzzer.cc
|
| diff --git a/testing/libfuzzer/fuzzers/template_url_parser_fuzzer.cc b/testing/libfuzzer/fuzzers/template_url_parser_fuzzer.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..4d1b762032e18148fbf504cbb574a7b5073b1827
|
| --- /dev/null
|
| +++ b/testing/libfuzzer/fuzzers/template_url_parser_fuzzer.cc
|
| @@ -0,0 +1,44 @@
|
| +// Copyright 2016 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.
|
| +
|
| +#include <stddef.h>
|
| +#include <stdint.h>
|
| +
|
| +#include <random>
|
| +#include <string>
|
| +
|
| +#include "components/search_engines/search_terms_data.h"
|
| +#include "components/search_engines/template_url.h"
|
| +#include "components/search_engines/template_url_parser.h"
|
| +
|
| +class PseudoRandomFilter : public TemplateURLParser::ParameterFilter {
|
| + public:
|
| + PseudoRandomFilter(uint32_t seed) : generator_(seed), pool_(0, 1) {}
|
| + ~PseudoRandomFilter() override = default;
|
| +
|
| + bool KeepParameter(const std::string&, const std::string&) override {
|
| + return pool_(generator_);
|
| + }
|
| +
|
| + private:
|
| + std::mt19937 generator_;
|
| + std::uniform_int_distribution<uint8_t> pool_;
|
| +};
|
| +
|
| +struct FuzzerFixedParams {
|
| + uint32_t seed_;
|
| +};
|
| +
|
| +extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
| + if (size < sizeof(FuzzerFixedParams)) {
|
| + return 0;
|
| + }
|
| + const FuzzerFixedParams* params =
|
| + reinterpret_cast<const FuzzerFixedParams*>(data);
|
| + size -= sizeof(FuzzerFixedParams);
|
| + const char* char_data = reinterpret_cast<const char*>(params + 1);
|
| + PseudoRandomFilter filter(params->seed_);
|
| + TemplateURLParser::Parse(SearchTermsData(), char_data, size, &filter);
|
| + return 0;
|
| +}
|
|
|