Chromium Code Reviews| Index: chrome/browser/extensions/api/socket/udp_socket_unittest.cc |
| diff --git a/chrome/browser/extensions/api/socket/udp_socket_unittest.cc b/chrome/browser/extensions/api/socket/udp_socket_unittest.cc |
| index c625efecdf27b66d73dbb2bde3d4639d2cacfa3c..6e0e585d0b38e1585caf520a859191decb381f33 100644 |
| --- a/chrome/browser/extensions/api/socket/udp_socket_unittest.cc |
| +++ b/chrome/browser/extensions/api/socket/udp_socket_unittest.cc |
| @@ -20,7 +20,7 @@ class UDPSocketUnitTest : public BrowserWithTestWindowTest { |
| }; |
| static void OnConnected(int result) { |
| - DCHECK(result == 0); |
| + EXPECT_EQ(0, result); |
| } |
| static void OnCompleted(int bytes_read, |
| @@ -30,8 +30,22 @@ static void OnCompleted(int bytes_read, |
| // Do nothing; don't care. |
| } |
| +static const char test_message[] = "$$TESTMESSAGETESTMESSAGETESTMESSAGETEST$$"; |
| +static const int test_message_length = ARRAYSIZE_UNSAFE(test_message); |
| + |
| +static void OnReadCompleted(int count, |
|
Bei Zhang
2013/04/23 17:26:53
Renamed to OnMulticastReadCompleted at line 102.
|
| + scoped_refptr<net::IOBuffer> io_buffer) { |
| + 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.
|
| + EXPECT_EQ(0, strncmp(io_buffer->data(), test_message, test_message_length)); |
| + MessageLoopForIO::current()->QuitWhenIdle(); |
| +} |
| + |
| +static void OnSendCompleted(int result) { |
| + EXPECT_EQ(static_cast<int>(test_message_length), result); |
| +} |
| + |
| TEST(UDPSocketUnitTest, TestUDPSocketRecvFrom) { |
| - MessageLoopForIO io_loop; // for RecvFrom to do its threaded work. |
| + MessageLoopForIO io_loop; // For RecvFrom to do its threaded work. |
| UDPSocket socket("abcdefghijklmnopqrst"); |
| // Confirm that we can call two RecvFroms in quick succession without |
| @@ -41,4 +55,75 @@ TEST(UDPSocketUnitTest, TestUDPSocketRecvFrom) { |
| socket.RecvFrom(4096, base::Bind(&OnCompleted)); |
| } |
| +TEST(UDPSocketUnitTest, TestUDPMulticastJoinGroup) { |
| + const char* kGroup = "237.132.100.17"; |
| + UDPSocket src("abcdefghijklmnopqrst"); |
| + UDPSocket dest("abcdefghijklmnopqrst"); |
| + |
| + EXPECT_EQ(0, dest.Bind("0.0.0.0", 13333)); |
| + EXPECT_EQ(0, dest.JoinGroup(kGroup)); |
| + base::hash_set<std::string> groups; |
| + dest.GetJoinedGroups(&groups); |
| + EXPECT_EQ(static_cast<size_t>(1), groups.size()); |
| + EXPECT_EQ(kGroup, *groups.begin()); |
| + EXPECT_NE(0, dest.LeaveGroup("237.132.100.13")); |
| + EXPECT_EQ(0, dest.LeaveGroup(kGroup)); |
| + dest.GetJoinedGroups(&groups); |
| + EXPECT_EQ(static_cast<size_t>(0), groups.size()); |
| +} |
| + |
| +TEST(UDPSocketUnitTest, TestUDPMulticastTimeToLive) { |
| + const char* kGroup = "237.132.100.17"; |
| + UDPSocket socket("abcdefghijklmnopqrst"); |
| + EXPECT_NE(0, socket.SetMulticastTimeToLive(-1)); // Negative TTL shall fail. |
| + EXPECT_EQ(0, socket.SetMulticastTimeToLive(3)); |
| + socket.Connect(kGroup, 13333, base::Bind(&OnConnected)); |
| +} |
| + |
| +TEST(UDPSocketUnitTest, TestUDPMulticastLoopbackMode) { |
| + const char* kGroup = "237.132.100.17"; |
| + UDPSocket socket("abcdefghijklmnopqrst"); |
| + EXPECT_EQ(0, socket.SetMulticastLoopbackMode(false)); |
| + socket.Connect(kGroup, 13333, base::Bind(&OnConnected)); |
| +} |
| + |
| +void OnMulticastSenderConnected(UDPSocket* src, |
| + 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.
|
| + if (result == 0) { |
| + scoped_refptr<net::IOBuffer> data = new net::WrappedIOBuffer(test_message); |
| + 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::
|
| + } else { |
| + FAIL() << "Failed to connect to multicast address. Error code: " << result; |
| + } |
| +} |
| + |
| +void Timeout(UDPSocket* dest, const char* loopback_addr, int port) { |
|
Bei Zhang
2013/04/23 17:26:53
Renamed to QuitMessageLoop at line 83.
|
| + 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.
|
| + scoped_refptr<net::IOBuffer> data = new net::WrappedIOBuffer(test_message); |
| + dest->SendTo(data, test_message_length, loopback_addr, |
| + port, base::Bind(&OnSendCompleted)); |
| +} |
| + |
| +TEST(UDPSocketUnitTest, TestUDPMulticastRecv) { |
| + const int kPort = 9999; |
| + const char* const kGroup = "237.132.100.17"; |
| + |
| + MessageLoopForIO io_loop; // For Read to do its threaded work. |
| + UDPSocket dest("abcdefghijklmnopqrst"); |
| + UDPSocket src("abcdefghijklmnopqrst"); |
| + |
| + EXPECT_EQ(0, src.SetMulticastTimeToLive(0)); |
| + EXPECT_EQ(0, dest.Bind("0.0.0.0", kPort)); |
| + EXPECT_EQ(0, dest.JoinGroup(kGroup)); |
| + dest.Read(1024, base::Bind(&OnReadCompleted)); |
| + |
| + // 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:
|
| + src.Connect(kGroup, kPort, base::Bind( |
| + &OnMulticastSenderConnected, &src, kGroup)); |
| + MessageLoopForIO::current()->PostDelayedTask(FROM_HERE, |
| + base::Bind(&Timeout, &dest, "0.0.0.0", kPort), |
| + base::TimeDelta::FromSeconds(4)); |
| + MessageLoopForIO::current()->Run(); |
| +} |
| + |
| } // namespace extensions |