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

Side by Side Diff: mojo/services/network/udp_socket_unittest.cc

Issue 664243002: Mojo UDP: add a client-side wrapper which handles the client<->server buffering (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git/+/master
Patch Set: Created 6 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
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "base/at_exit.h" 5 #include "base/at_exit.h"
6 #include "base/macros.h" 6 #include "base/macros.h"
7 #include "base/memory/scoped_ptr.h" 7 #include "base/memory/scoped_ptr.h"
8 #include "mojo/public/cpp/bindings/callback.h" 8 #include "mojo/public/cpp/bindings/callback.h"
9 #include "mojo/services/public/cpp/network/udp_socket_wrapper.h"
9 #include "mojo/services/public/interfaces/network/network_service.mojom.h" 10 #include "mojo/services/public/interfaces/network/network_service.mojom.h"
10 #include "mojo/services/public/interfaces/network/udp_socket.mojom.h" 11 #include "mojo/services/public/interfaces/network/udp_socket.mojom.h"
11 #include "mojo/shell/shell_test_helper.h" 12 #include "mojo/shell/shell_test_helper.h"
12 #include "net/base/net_errors.h" 13 #include "net/base/net_errors.h"
13 #include "testing/gtest/include/gtest/gtest.h" 14 #include "testing/gtest/include/gtest/gtest.h"
14 #include "url/gurl.h" 15 #include "url/gurl.h"
15 16
16 namespace mojo { 17 namespace mojo {
17 namespace service { 18 namespace service {
18 namespace { 19 namespace {
(...skipping 12 matching lines...) Expand all
31 return addr.Pass(); 32 return addr.Pass();
32 } 33 }
33 34
34 Array<uint8_t> CreateTestMessage(uint8_t initial, size_t size) { 35 Array<uint8_t> CreateTestMessage(uint8_t initial, size_t size) {
35 Array<uint8_t> array(size); 36 Array<uint8_t> array(size);
36 for (size_t i = 0; i < size; ++i) 37 for (size_t i = 0; i < size; ++i)
37 array[i] = static_cast<uint8_t>((i + initial) % 256); 38 array[i] = static_cast<uint8_t>((i + initial) % 256);
38 return array.Pass(); 39 return array.Pass();
39 } 40 }
40 41
41 bool AreEqualArrays(const Array<uint8_t>& array_1,
42 const Array<uint8_t>& array_2) {
43 if (array_1.is_null() != array_2.is_null())
44 return false;
45 else if (array_1.is_null())
46 return true;
47
48 if (array_1.size() != array_2.size())
49 return false;
50
51 for (size_t i = 0; i < array_1.size(); ++i) {
52 if (array_1[i] != array_2[i])
53 return false;
54 }
55
56 return true;
57 }
58
59 template <typename CallbackType> 42 template <typename CallbackType>
60 class TestCallbackBase { 43 class TestCallbackBase {
61 public: 44 public:
62 TestCallbackBase() : state_(nullptr), run_loop_(nullptr), ran_(false) {} 45 TestCallbackBase() : state_(nullptr), run_loop_(nullptr), ran_(false) {}
63 46
64 ~TestCallbackBase() { 47 ~TestCallbackBase() {
65 state_->set_test_callback(nullptr); 48 state_->set_test_callback(nullptr);
66 } 49 }
67 50
68 CallbackType callback() const { return callback_; } 51 CallbackType callback() const { return callback_; }
(...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after
196 static_cast<TestCallbackWithUint32*>(test_callback_); 179 static_cast<TestCallbackWithUint32*>(test_callback_);
197 callback->result_ = result; 180 callback->result_ = result;
198 } 181 }
199 NotifyRun(); 182 NotifyRun();
200 } 183 }
201 }; 184 };
202 185
203 uint32_t result_; 186 uint32_t result_;
204 }; 187 };
205 188
189 class TestReceiveCallback
190 : public TestCallbackBase<
191 Callback<void(NetworkErrorPtr, NetAddressPtr, Array<uint8_t>)>> {
192 public:
193 TestReceiveCallback() {
194 Initialize(new State());
195 }
196 ~TestReceiveCallback() {}
197
198 const NetworkErrorPtr& result() const { return result_; }
199 const NetAddressPtr& src_addr() const { return src_addr_; }
200 const Array<uint8_t>& data() const { return data_; }
201
202 private:
203 struct State : public StateBase {
204 virtual ~State() {}
205
206 virtual void Run(NetworkErrorPtr result,
207 NetAddressPtr src_addr,
208 Array<uint8_t> data) const override {
209 if (test_callback_) {
210 TestReceiveCallback* callback =
211 static_cast<TestReceiveCallback*>(test_callback_);
212 callback->result_ = result.Pass();
213 callback->src_addr_ = src_addr.Pass();
214 callback->data_ = data.Pass();
215 }
216 NotifyRun();
217 }
218 };
219
220 NetworkErrorPtr result_;
221 NetAddressPtr src_addr_;
222 Array<uint8_t> data_;
223 };
224
206 class UDPSocketTest : public testing::Test { 225 class UDPSocketTest : public testing::Test {
207 public: 226 public:
208 UDPSocketTest() {} 227 UDPSocketTest() {}
209 virtual ~UDPSocketTest() {} 228 virtual ~UDPSocketTest() {}
210 229
211 virtual void SetUp() override { 230 virtual void SetUp() override {
212 test_helper_.Init(); 231 test_helper_.Init();
213 232
214 test_helper_.application_manager()->ConnectToService( 233 test_helper_.application_manager()->ConnectToService(
215 GURL("mojo:mojo_network_service"), &network_service_); 234 GURL("mojo:mojo_network_service"), &network_service_);
(...skipping 133 matching lines...) Expand 10 before | Expand all | Expand 10 after
349 368
350 UDPSocketPtr client_socket; 369 UDPSocketPtr client_socket;
351 network_service_->CreateUDPSocket(GetProxy(&client_socket)); 370 network_service_->CreateUDPSocket(GetProxy(&client_socket));
352 371
353 TestCallbackWithAddress callback2; 372 TestCallbackWithAddress callback2;
354 client_socket->Bind(GetLocalHostWithAnyPort(), callback2.callback()); 373 client_socket->Bind(GetLocalHostWithAnyPort(), callback2.callback());
355 callback2.WaitForResult(); 374 callback2.WaitForResult();
356 ASSERT_EQ(net::OK, callback2.result()->code); 375 ASSERT_EQ(net::OK, callback2.result()->code);
357 ASSERT_NE(0u, callback2.net_address()->ipv4->port); 376 ASSERT_NE(0u, callback2.net_address()->ipv4->port);
358 377
378 NetAddressPtr client_addr = callback2.net_address().Clone();
379
359 const size_t kDatagramCount = 6; 380 const size_t kDatagramCount = 6;
360 const size_t kDatagramSize = 255; 381 const size_t kDatagramSize = 255;
361 udp_socket_->ReceiveMore(kDatagramCount); 382 udp_socket_->ReceiveMore(kDatagramCount);
362 383
363 for (size_t i = 0; i < kDatagramCount; ++i) { 384 for (size_t i = 0; i < kDatagramCount; ++i) {
364 TestCallback callback; 385 TestCallback callback;
365 client_socket->SendTo( 386 client_socket->SendTo(
366 server_addr.Clone(), 387 server_addr.Clone(),
367 CreateTestMessage(static_cast<uint8_t>(i), kDatagramSize), 388 CreateTestMessage(static_cast<uint8_t>(i), kDatagramSize),
368 callback.callback()); 389 callback.callback());
369 callback.WaitForResult(); 390 callback.WaitForResult();
370 EXPECT_EQ(255, callback.result()->code); 391 EXPECT_EQ(255, callback.result()->code);
371 } 392 }
372 393
373 WaitForReceiveResults(kDatagramCount); 394 WaitForReceiveResults(kDatagramCount);
374 for (size_t i = 0; i < kDatagramCount; ++i) { 395 for (size_t i = 0; i < kDatagramCount; ++i) {
375 scoped_ptr<ReceiveResult> result(GetReceiveResults()->front()); 396 scoped_ptr<ReceiveResult> result(GetReceiveResults()->front());
376 GetReceiveResults()->pop(); 397 GetReceiveResults()->pop();
377 398
378 EXPECT_EQ(static_cast<int>(kDatagramSize), result->result->code); 399 EXPECT_EQ(static_cast<int>(kDatagramSize), result->result->code);
379 EXPECT_TRUE(AreEqualArrays( 400 EXPECT_TRUE(result->addr.Equals(client_addr));
380 CreateTestMessage(static_cast<uint8_t>(i), kDatagramSize), 401 EXPECT_TRUE(result->data.Equals(
381 result->data)); 402 CreateTestMessage(static_cast<uint8_t>(i), kDatagramSize)));
382 } 403 }
383 } 404 }
384 405
406 TEST_F(UDPSocketTest, TestUDPSocketWrapper) {
407 UDPSocketWrapper udp_socket(udp_socket_.Pass(), 4, 4);
408
409 TestCallbackWithAddress callback1;
410 udp_socket.Bind(GetLocalHostWithAnyPort(), callback1.callback());
411 callback1.WaitForResult();
412 ASSERT_EQ(net::OK, callback1.result()->code);
413 ASSERT_NE(0u, callback1.net_address()->ipv4->port);
414
415 NetAddressPtr server_addr = callback1.net_address().Clone();
416
417 UDPSocketPtr raw_client_socket;
418 network_service_->CreateUDPSocket(GetProxy(&raw_client_socket));
419 UDPSocketWrapper client_socket(raw_client_socket.Pass(), 4, 4);
420
421 TestCallbackWithAddress callback2;
422 client_socket.Bind(GetLocalHostWithAnyPort(), callback2.callback());
423 callback2.WaitForResult();
424 ASSERT_EQ(net::OK, callback2.result()->code);
425 ASSERT_NE(0u, callback2.net_address()->ipv4->port);
426
427 NetAddressPtr client_addr = callback2.net_address().Clone();
428
429 const size_t kDatagramCount = 16;
430 const size_t kDatagramSize = 255;
431
432 for (size_t i = 1; i < kDatagramCount; ++i) {
433 TestCallback* send_callbacks = new TestCallback[i];
brettw 2014/10/21 18:21:33 Can you use scoped_ptr<TestCallback[]> and same fo
yzshen1 2014/10/21 21:59:30 Done.
434 TestReceiveCallback* receive_callbacks = new TestReceiveCallback[i];
435
436 for (size_t j = 0; j < i; ++j) {
437 client_socket.SendTo(
438 server_addr.Clone(),
439 CreateTestMessage(static_cast<uint8_t>(j), kDatagramSize),
440 send_callbacks[j].callback());
441
442 udp_socket.ReceiveFrom(receive_callbacks[j].callback());
443 }
444
445 receive_callbacks[i - 1].WaitForResult();
446
447 for (size_t j = 0; j < i; ++j) {
448 EXPECT_EQ(static_cast<int>(kDatagramSize),
449 receive_callbacks[j].result()->code);
450 EXPECT_TRUE(receive_callbacks[j].src_addr().Equals(client_addr));
451 EXPECT_TRUE(receive_callbacks[j].data().Equals(
452 CreateTestMessage(static_cast<uint8_t>(j), kDatagramSize)));
453 }
454
455 delete[] send_callbacks;
456 delete[] receive_callbacks;
457 }
458 }
459
385 } // namespace service 460 } // namespace service
386 } // namespace mojo 461 } // namespace mojo
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698