Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(649)

Side by Side Diff: webrtc/test/fuzzers/pseudotcp_parser_fuzzer.cc

Issue 2365373002: Add autothread to pseudo-tcp fuzzer. (Closed)
Patch Set: Added const, comments for thread. Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #include <stddef.h> 11 #include <stddef.h>
12 #include <stdint.h> 12 #include <stdint.h>
13 13
14 #include "webrtc/base/thread.h"
14 #include "webrtc/p2p/base/pseudotcp.h" 15 #include "webrtc/p2p/base/pseudotcp.h"
15 16
16 namespace webrtc { 17 namespace webrtc {
17 class FakeIPseudoTcpNotify : public cricket::IPseudoTcpNotify { 18 class FakeIPseudoTcpNotify : public cricket::IPseudoTcpNotify {
18 public: 19 public:
19 void OnTcpOpen(cricket::PseudoTcp* tcp) {} 20 void OnTcpOpen(cricket::PseudoTcp* tcp) {}
20 void OnTcpReadable(cricket::PseudoTcp* tcp) {} 21 void OnTcpReadable(cricket::PseudoTcp* tcp) {}
21 void OnTcpWriteable(cricket::PseudoTcp* tcp) {} 22 void OnTcpWriteable(cricket::PseudoTcp* tcp) {}
22 void OnTcpClosed(cricket::PseudoTcp* tcp, uint32_t error) {} 23 void OnTcpClosed(cricket::PseudoTcp* tcp, uint32_t error) {}
23 24
24 cricket::IPseudoTcpNotify::WriteResult TcpWritePacket(cricket::PseudoTcp* tcp, 25 cricket::IPseudoTcpNotify::WriteResult TcpWritePacket(cricket::PseudoTcp* tcp,
25 const char* buffer, 26 const char* buffer,
26 size_t len) { 27 size_t len) {
27 return cricket::IPseudoTcpNotify::WriteResult::WR_SUCCESS; 28 return cricket::IPseudoTcpNotify::WriteResult::WR_SUCCESS;
28 } 29 }
29 }; 30 };
30 31
31 struct Environment { 32 struct Environment {
32 cricket::PseudoTcp* ptcp; 33 explicit Environment(cricket::IPseudoTcpNotify* notifier):
33 explicit Environment(cricket::IPseudoTcpNotify* notifier) { 34 ptcp(new cricket::PseudoTcp(notifier, 0)) {
34 ptcp = new cricket::PseudoTcp(notifier, 0);
35 } 35 }
36
37 cricket::PseudoTcp* const ptcp;
38
39 // We need the thread to avoid some uninteresting crashes, since the
40 // production code expects there to be a thread object available.
41 rtc::AutoThread thread;
36 }; 42 };
37 43
38 Environment* env = new Environment(new FakeIPseudoTcpNotify()); 44 Environment* env = new Environment(new FakeIPseudoTcpNotify());
39 45
40 void FuzzOneInput(const uint8_t* data, size_t size) { 46 void FuzzOneInput(const uint8_t* data, size_t size) {
41 env->ptcp->NotifyPacket(reinterpret_cast<const char*>(data), size); 47 env->ptcp->NotifyPacket(reinterpret_cast<const char*>(data), size);
42 } 48 }
43 } // namespace webrtc 49 } // namespace webrtc
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698