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 | |
mmoroz | 1622efb | 2015-12-08 01:26:23 | [diff] [blame] | 8 | #include <vector> |
| 9 | |
ricea | 105ae61 | 2016-09-08 08:00:07 | [diff] [blame] | 10 | #include "base/test/fuzzed_data_provider.h" |
mmoroz | 1622efb | 2015-12-08 01:26:23 | [diff] [blame] | 11 | #include "net/websockets/websocket_frame_parser.h" |
| 12 | |
| 13 | // Entry point for LibFuzzer. |
mmoroz | e87d66d5 | 2016-02-05 19:10:57 | [diff] [blame] | 14 | extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { |
ricea | 105ae61 | 2016-09-08 08:00:07 | [diff] [blame] | 15 | base::FuzzedDataProvider fuzzed_data_provider(data, size); |
mmoroz | 1622efb | 2015-12-08 01:26:23 | [diff] [blame] | 16 | net::WebSocketFrameParser parser; |
danakj | 9c5cab5 | 2016-04-16 00:54:33 | [diff] [blame] | 17 | std::vector<std::unique_ptr<net::WebSocketFrameChunk>> frame_chunks; |
ricea | 105ae61 | 2016-09-08 08:00:07 | [diff] [blame] | 18 | while (fuzzed_data_provider.remaining_bytes() > 0) { |
Abhishek Arya | 5b644f6 | 2018-11-28 00:47:17 | [diff] [blame] | 19 | size_t chunk_size = fuzzed_data_provider.ConsumeIntegralInRange(1, 32); |
Max Moroz | c416f80 | 2018-11-21 22:15:42 | [diff] [blame] | 20 | std::vector<char> chunk = |
| 21 | fuzzed_data_provider.ConsumeBytes<char>(chunk_size); |
ricea | 105ae61 | 2016-09-08 08:00:07 | [diff] [blame] | 22 | parser.Decode(chunk.data(), chunk.size(), &frame_chunks); |
| 23 | } |
mmoroz | 1622efb | 2015-12-08 01:26:23 | [diff] [blame] | 24 | return 0; |
| 25 | } |