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

Unified 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 side-by-side diff with in-line comments
Download patch
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

Powered by Google App Engine
This is Rietveld 408576698