blob: fec7feaf677234740eaa8a55bc64b4586e839234 [file] [log] [blame]
// 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 "net/base/mime_sniffer.h"
#include <stddef.h>
#include <stdint.h>
#include <string>
#include "base/strings/string_piece.h"
#include "url/gurl.h"
namespace {
// Finds the line break in |input|, removes every thing up to and including the
// line break from |input|, and returns everything up to the line break as a
// string.
std::string GetNextArgument(base::StringPiece* input) {
base::StringPiece::size_type argument_end = input->find('\n');
if (argument_end == base::StringPiece::npos)
argument_end = input->size();
base::StringPiece argument = input->substr(0, argument_end);
*input = input->substr(argument_end + 1);
return argument.as_string();
} // namespace
// Fuzzer for the two main mime sniffing functions:
// SniffMimeType and SniffMimeTypeFromLocalData.
// Breaks |data| up into 3 substrings: URL, MIME type hint, and content, and
// passes them to the MIME sniffing functions (SniffMimeTypeFromLocalData
// does not take all 3 arguments). The first two substrings are each on their
// own line, and content is everything after them. Since neither URLs nor
// content-encoding headers can have line breaks, this doesn't reduce coverage.
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
base::StringPiece input(reinterpret_cast<const char*>(data), size);
GURL url(GetNextArgument(&input));
std::string mime_type_hint = GetNextArgument(&input);
std::string result;
net::SniffMimeType(, input.length(), url, mime_type_hint,
net::SniffMimeTypeFromLocalData(, input.length(), &result);
return 0;