mmoroz | e87d66d5 | 2016-02-05 19:10:57 | [diff] [blame] | 1 | // Copyright 2015 The Chromium Authors. All rights reserved. |
mmoroz | 1622efb | 2015-12-08 01:26:23 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
mmoroz | e87d66d5 | 2016-02-05 19:10:57 | [diff] [blame] | 5 | #include <stddef.h> |
| 6 | #include <stdint.h> |
| 7 | |
Max Moroz | a1707f4 | 2019-08-28 21:10:28 | [diff] [blame] | 8 | #include <fuzzer/FuzzedDataProvider.h> |
| 9 | |
mmoroz | 1622efb | 2015-12-08 01:26:23 | [diff] [blame] | 10 | #include <vector> |
| 11 | |
| 12 | #include "net/websockets/websocket_frame_parser.h" |
| 13 | |
| 14 | // Entry point for LibFuzzer. |
mmoroz | e87d66d5 | 2016-02-05 19:10:57 | [diff] [blame] | 15 | extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { |
Max Moroz | cfbe47cc | 2019-06-24 17:45:02 | [diff] [blame] | 16 | FuzzedDataProvider fuzzed_data_provider(data, size); |
mmoroz | 1622efb | 2015-12-08 01:26:23 | [diff] [blame] | 17 | net::WebSocketFrameParser parser; |
danakj | 9c5cab5 | 2016-04-16 00:54:33 | [diff] [blame] | 18 | std::vector<std::unique_ptr<net::WebSocketFrameChunk>> frame_chunks; |
ricea | 105ae61 | 2016-09-08 08:00:07 | [diff] [blame] | 19 | while (fuzzed_data_provider.remaining_bytes() > 0) { |
Abhishek Arya | 5b644f6 | 2018-11-28 00:47:17 | [diff] [blame] | 20 | size_t chunk_size = fuzzed_data_provider.ConsumeIntegralInRange(1, 32); |
Max Moroz | c416f80 | 2018-11-21 22:15:42 | [diff] [blame] | 21 | std::vector<char> chunk = |
| 22 | fuzzed_data_provider.ConsumeBytes<char>(chunk_size); |
ricea | 105ae61 | 2016-09-08 08:00:07 | [diff] [blame] | 23 | parser.Decode(chunk.data(), chunk.size(), &frame_chunks); |
| 24 | } |
mmoroz | 1622efb | 2015-12-08 01:26:23 | [diff] [blame] | 25 | return 0; |
| 26 | } |