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

Side by Side Diff: chrome/browser/extensions/api/socket/udp_socket_unittest.cc

Issue 12684008: Multicast socket API (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Disable multicast test on android Created 7 years, 8 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "chrome/browser/extensions/api/socket/udp_socket.h" 5 #include "chrome/browser/extensions/api/socket/udp_socket.h"
6 6
7 #include <string> 7 #include <string>
8 8
9 #include "base/memory/scoped_ptr.h" 9 #include "base/memory/scoped_ptr.h"
10 #include "base/message_loop.h" 10 #include "base/message_loop.h"
11 #include "chrome/test/base/browser_with_test_window_test.h" 11 #include "chrome/test/base/browser_with_test_window_test.h"
12 #include "net/base/io_buffer.h" 12 #include "net/base/io_buffer.h"
13 #include "testing/gtest/include/gtest/gtest.h" 13 #include "testing/gtest/include/gtest/gtest.h"
14 14
15 namespace extensions { 15 namespace extensions {
16 16
17 // UDPSocketUnitTest exists solely to make it easier to pass a specific 17 // UDPSocketUnitTest exists solely to make it easier to pass a specific
18 // gtest_filter argument during development. 18 // gtest_filter argument during development.
19 class UDPSocketUnitTest : public BrowserWithTestWindowTest { 19 class UDPSocketUnitTest : public BrowserWithTestWindowTest {
20 }; 20 };
21 21
22 static void OnConnected(int result) { 22 static void OnConnected(int result) {
23 DCHECK(result == 0); 23 EXPECT_EQ(0, result);
24 } 24 }
25 25
26 static void OnCompleted(int bytes_read, 26 static void OnCompleted(int bytes_read,
27 scoped_refptr<net::IOBuffer> io_buffer, 27 scoped_refptr<net::IOBuffer> io_buffer,
28 const std::string& address, 28 const std::string& address,
29 int port) { 29 int port) {
30 // Do nothing; don't care. 30 // Do nothing; don't care.
31 } 31 }
32 32
33 static const char test_message[] = "$$TESTMESSAGETESTMESSAGETESTMESSAGETEST$$";
34 static const int test_message_length = ARRAYSIZE_UNSAFE(test_message);
35
36 static void OnReadCompleted(int count,
Bei Zhang 2013/04/23 17:26:53 Renamed to OnMulticastReadCompleted at line 102.
37 scoped_refptr<net::IOBuffer> io_buffer) {
38 EXPECT_EQ(static_cast<int>(test_message_length), count);
wtc 2013/04/22 19:19:53 The static_cast<int> can be removed because you de
Bei Zhang 2013/04/23 17:26:53 Done.
39 EXPECT_EQ(0, strncmp(io_buffer->data(), test_message, test_message_length));
40 MessageLoopForIO::current()->QuitWhenIdle();
41 }
42
43 static void OnSendCompleted(int result) {
44 EXPECT_EQ(static_cast<int>(test_message_length), result);
45 }
46
33 TEST(UDPSocketUnitTest, TestUDPSocketRecvFrom) { 47 TEST(UDPSocketUnitTest, TestUDPSocketRecvFrom) {
34 MessageLoopForIO io_loop; // for RecvFrom to do its threaded work. 48 MessageLoopForIO io_loop; // For RecvFrom to do its threaded work.
35 UDPSocket socket("abcdefghijklmnopqrst"); 49 UDPSocket socket("abcdefghijklmnopqrst");
36 50
37 // Confirm that we can call two RecvFroms in quick succession without 51 // Confirm that we can call two RecvFroms in quick succession without
38 // triggering crbug.com/146606. 52 // triggering crbug.com/146606.
39 socket.Connect("127.0.0.1", 40000, base::Bind(&OnConnected)); 53 socket.Connect("127.0.0.1", 40000, base::Bind(&OnConnected));
40 socket.RecvFrom(4096, base::Bind(&OnCompleted)); 54 socket.RecvFrom(4096, base::Bind(&OnCompleted));
41 socket.RecvFrom(4096, base::Bind(&OnCompleted)); 55 socket.RecvFrom(4096, base::Bind(&OnCompleted));
42 } 56 }
43 57
58 TEST(UDPSocketUnitTest, TestUDPMulticastJoinGroup) {
59 const char* kGroup = "237.132.100.17";
60 UDPSocket src("abcdefghijklmnopqrst");
61 UDPSocket dest("abcdefghijklmnopqrst");
62
63 EXPECT_EQ(0, dest.Bind("0.0.0.0", 13333));
64 EXPECT_EQ(0, dest.JoinGroup(kGroup));
65 base::hash_set<std::string> groups;
66 dest.GetJoinedGroups(&groups);
67 EXPECT_EQ(static_cast<size_t>(1), groups.size());
68 EXPECT_EQ(kGroup, *groups.begin());
69 EXPECT_NE(0, dest.LeaveGroup("237.132.100.13"));
70 EXPECT_EQ(0, dest.LeaveGroup(kGroup));
71 dest.GetJoinedGroups(&groups);
72 EXPECT_EQ(static_cast<size_t>(0), groups.size());
73 }
74
75 TEST(UDPSocketUnitTest, TestUDPMulticastTimeToLive) {
76 const char* kGroup = "237.132.100.17";
77 UDPSocket socket("abcdefghijklmnopqrst");
78 EXPECT_NE(0, socket.SetMulticastTimeToLive(-1)); // Negative TTL shall fail.
79 EXPECT_EQ(0, socket.SetMulticastTimeToLive(3));
80 socket.Connect(kGroup, 13333, base::Bind(&OnConnected));
81 }
82
83 TEST(UDPSocketUnitTest, TestUDPMulticastLoopbackMode) {
84 const char* kGroup = "237.132.100.17";
85 UDPSocket socket("abcdefghijklmnopqrst");
86 EXPECT_EQ(0, socket.SetMulticastLoopbackMode(false));
87 socket.Connect(kGroup, 13333, base::Bind(&OnConnected));
88 }
89
90 void OnMulticastSenderConnected(UDPSocket* src,
91 const char* group, int result) {
wtc 2013/04/22 19:19:53 It may be better to list one parameter per line.
Bei Zhang 2013/04/23 17:26:53 Done. Renamed to SendMulticastPacket at line 87.
92 if (result == 0) {
93 scoped_refptr<net::IOBuffer> data = new net::WrappedIOBuffer(test_message);
94 src->Write(data, test_message_length, base::Bind(&OnSendCompleted));
wtc 2013/04/22 19:19:53 Should we check the return value of src->Write()?
Bei Zhang 2013/04/23 17:26:53 extensions::Socket::Write and extensions::Socket::
95 } else {
96 FAIL() << "Failed to connect to multicast address. Error code: " << result;
97 }
98 }
99
100 void Timeout(UDPSocket* dest, const char* loopback_addr, int port) {
Bei Zhang 2013/04/23 17:26:53 Renamed to QuitMessageLoop at line 83.
101 FAIL() << "Failed to recveive from multicast address";
wtc 2013/04/22 19:19:53 Typo: recveive => receive
Bei Zhang 2013/04/23 17:26:53 Done.
102 scoped_refptr<net::IOBuffer> data = new net::WrappedIOBuffer(test_message);
103 dest->SendTo(data, test_message_length, loopback_addr,
104 port, base::Bind(&OnSendCompleted));
105 }
106
107 TEST(UDPSocketUnitTest, TestUDPMulticastRecv) {
108 const int kPort = 9999;
109 const char* const kGroup = "237.132.100.17";
110
111 MessageLoopForIO io_loop; // For Read to do its threaded work.
112 UDPSocket dest("abcdefghijklmnopqrst");
113 UDPSocket src("abcdefghijklmnopqrst");
114
115 EXPECT_EQ(0, src.SetMulticastTimeToLive(0));
116 EXPECT_EQ(0, dest.Bind("0.0.0.0", kPort));
117 EXPECT_EQ(0, dest.JoinGroup(kGroup));
118 dest.Read(1024, base::Bind(&OnReadCompleted));
119
120 // Wait for 2 seconds for the JoinGroup to take effect.
wtc 2013/04/22 19:19:53 This comment says "2 seconds", but you seem to wai
Bei Zhang 2013/04/23 17:26:53 Done. On 2013/04/22 19:19:53, wtc wrote:
121 src.Connect(kGroup, kPort, base::Bind(
122 &OnMulticastSenderConnected, &src, kGroup));
123 MessageLoopForIO::current()->PostDelayedTask(FROM_HERE,
124 base::Bind(&Timeout, &dest, "0.0.0.0", kPort),
125 base::TimeDelta::FromSeconds(4));
126 MessageLoopForIO::current()->Run();
127 }
128
44 } // namespace extensions 129 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698