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

Side by Side Diff: net/udp/udp_socket_perftest.cc

Issue 861963002: UDP: Windows implementation using non-blocking IO (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: nits Created 5 years, 11 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
OLDNEW
(Empty)
1 // Copyright 2015 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/basictypes.h"
6 #include "base/bind.h"
7 #include "base/memory/weak_ptr.h"
8 #include "base/run_loop.h"
9 #include "base/test/perf_time_logger.h"
10 #include "net/base/io_buffer.h"
11 #include "net/base/ip_endpoint.h"
12 #include "net/base/net_errors.h"
13 #include "net/base/net_log_unittest.h"
14 #include "net/base/net_util.h"
15 #include "net/base/test_completion_callback.h"
16 #include "net/test/net_test_suite.h"
17 #include "net/udp/udp_client_socket.h"
18 #include "net/udp/udp_server_socket.h"
19 #include "net/udp/udp_socket.h"
20 #include "testing/gtest/include/gtest/gtest.h"
21 #include "testing/platform_test.h"
22
23 namespace {
24
25 class UDPSocketPerfTest : public PlatformTest {
26 public:
27 UDPSocketPerfTest()
28 : buffer_(new net::IOBufferWithSize(kPacketSize)), weak_factory_(this) {}
29
30 void DoneWritePacketsToSocket(net::UDPClientSocket* socket,
31 int num_of_packets,
32 base::Closure done_callback,
33 int error) {
34 WritePacketsToSocket(socket, num_of_packets, done_callback);
35 }
36
37 // Send |num_of_packets| to |socket|. Invoke |done_callback| when done.
38 void WritePacketsToSocket(net::UDPClientSocket* socket,
39 int num_of_packets,
40 base::Closure done_callback);
41
42 // Use non-blocking IO if |use_nonblocking_io| is true. This variable only
43 // has effect on Windows.
44 void WriteBenchmark(bool use_nonblocking_io);
45
46 protected:
47 static const int kPacketSize = 1024;
48 scoped_refptr<net::IOBufferWithSize> buffer_;
49 base::WeakPtrFactory<UDPSocketPerfTest> weak_factory_;
50 };
51
52 // Creates and address from an ip/port and returns it in |address|.
53 void CreateUDPAddress(std::string ip_str,
54 uint16 port,
55 net::IPEndPoint* address) {
56 net::IPAddressNumber ip_number;
57 bool rv = net::ParseIPLiteralToNumber(ip_str, &ip_number);
58 if (!rv)
59 return;
60 *address = net::IPEndPoint(ip_number, port);
61 }
62
63 void UDPSocketPerfTest::WritePacketsToSocket(net::UDPClientSocket* socket,
64 int num_of_packets,
65 base::Closure done_callback) {
66 scoped_refptr<net::IOBufferWithSize> io_buffer(
67 new net::IOBufferWithSize(kPacketSize));
68 memset(io_buffer->data(), 'G', kPacketSize);
69
70 while (num_of_packets) {
71 int rv =
72 socket->Write(io_buffer.get(), io_buffer->size(),
73 base::Bind(&UDPSocketPerfTest::DoneWritePacketsToSocket,
74 weak_factory_.GetWeakPtr(), socket,
75 num_of_packets - 1, done_callback));
76 if (rv == net::ERR_IO_PENDING)
77 break;
78 --num_of_packets;
79 }
80 if (!num_of_packets) {
81 done_callback.Run();
82 return;
83 }
84 }
85
86 void UDPSocketPerfTest::WriteBenchmark(bool use_nonblocking_io) {
87 const uint16 kPort = 9999;
88 std::string simple_message("hello world!");
89
90 // Setup the server to listen.
91 net::IPEndPoint bind_address;
92 CreateUDPAddress("127.0.0.1", kPort, &bind_address);
93 net::CapturingNetLog server_log;
94 scoped_ptr<net::UDPServerSocket> server(
95 new net::UDPServerSocket(&server_log, net::NetLog::Source()));
96 #if defined(OS_WIN)
97 if (use_nonblocking_io)
98 server->UseNonBlockingIO();
99 #endif
100 int rv = server->Listen(bind_address);
101 ASSERT_EQ(net::OK, rv);
102
103 // Setup the client.
104 net::IPEndPoint server_address;
105 CreateUDPAddress("127.0.0.1", kPort, &server_address);
106 net::CapturingNetLog client_log;
107 scoped_ptr<net::UDPClientSocket> client(new net::UDPClientSocket(
108 net::DatagramSocket::DEFAULT_BIND, net::RandIntCallback(), &client_log,
109 net::NetLog::Source()));
110 #if defined(OS_WIN)
111 if (use_nonblocking_io)
112 client->UseNonBlockingIO();
113 #endif
114 rv = client->Connect(server_address);
115 EXPECT_EQ(net::OK, rv);
116
117 base::RunLoop run_loop;
118 base::TimeTicks start_ticks = base::TimeTicks::Now();
119 int packets = 100000;
120 client->SetSendBufferSize(1024 * 128);
121 WritePacketsToSocket(client.get(), packets, run_loop.QuitClosure());
122 run_loop.Run();
123
124 double elapsed = (base::TimeTicks::Now() - start_ticks).InSecondsF();
125 LOG(INFO) << "Write speed: " << packets / 1024 / elapsed << " MB/s";
126 }
127
128 TEST_F(UDPSocketPerfTest, Write) {
129 base::PerfTimeLogger timer("UDP_socket_write");
130 WriteBenchmark(false);
131 }
132
133 #if defined(OS_WIN)
134 TEST_F(UDPSocketPerfTest, WriteNonBlocking) {
135 base::PerfTimeLogger timer("UDP_socket_write_nonblocking");
136 WriteBenchmark(true);
137 }
138 #endif
139
140 } // namespace
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698