| OLD | NEW |
| (Empty) |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "base/at_exit.h" | |
| 6 #include "base/command_line.h" | |
| 7 #include "base/files/file_util.h" | |
| 8 #include "net/spdy/fuzzing/hpack_fuzz_util.h" | |
| 9 | |
| 10 namespace { | |
| 11 | |
| 12 // Specifies a file having HPACK header sets. | |
| 13 const char kFileToParse[] = "file-to-parse"; | |
| 14 | |
| 15 } // namespace | |
| 16 | |
| 17 using base::StringPiece; | |
| 18 using net::HpackFuzzUtil; | |
| 19 using std::string; | |
| 20 | |
| 21 // Sequentially runs each given length-prefixed header block through | |
| 22 // decoding and encoding fuzzing stages (using HpackFuzzUtil). | |
| 23 int main(int argc, char** argv) { | |
| 24 base::AtExitManager exit_manager; | |
| 25 | |
| 26 base::CommandLine::Init(argc, argv); | |
| 27 const base::CommandLine& command_line = | |
| 28 *base::CommandLine::ForCurrentProcess(); | |
| 29 | |
| 30 if (!command_line.HasSwitch(kFileToParse)) { | |
| 31 LOG(ERROR) << "Usage: " << argv[0] | |
| 32 << " --" << kFileToParse << "=/path/to/file.in"; | |
| 33 return -1; | |
| 34 } | |
| 35 string file_to_parse = command_line.GetSwitchValueASCII(kFileToParse); | |
| 36 | |
| 37 // ClusterFuzz may invoke as --file-to-parse="". Don't crash in this case. | |
| 38 if (file_to_parse.empty()) { | |
| 39 LOG(WARNING) << "Empty file to parse given. Doing nothing."; | |
| 40 return 0; | |
| 41 } | |
| 42 | |
| 43 DVLOG(1) << "Reading input from " << file_to_parse; | |
| 44 HpackFuzzUtil::Input input; | |
| 45 CHECK(base::ReadFileToString(base::FilePath::FromUTF8Unsafe(file_to_parse), | |
| 46 &input.input)); | |
| 47 | |
| 48 HpackFuzzUtil::FuzzerContext context; | |
| 49 HpackFuzzUtil::InitializeFuzzerContext(&context); | |
| 50 | |
| 51 size_t block_count = 0; | |
| 52 StringPiece block; | |
| 53 while (HpackFuzzUtil::NextHeaderBlock(&input, &block)) { | |
| 54 HpackFuzzUtil::RunHeaderBlockThroughFuzzerStages(&context, block); | |
| 55 ++block_count; | |
| 56 } | |
| 57 DVLOG(1) << "Fuzzed " << block_count << " blocks."; | |
| 58 return 0; | |
| 59 } | |
| OLD | NEW |