Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 |
| OLD | NEW |