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

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: Fix tests 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..7b9bd5929204b7aaf0596e8c9949c237fa097802 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(result, 0);
mmenke 2013/04/12 21:07:41 Expected value should be the first argument, the v
Bei Zhang 2013/04/15 22:30:26 Done.
}
static void OnCompleted(int bytes_read,
@@ -30,6 +30,19 @@ static void OnCompleted(int bytes_read,
// Do nothing; don't care.
}
+static const char test_message[] = "$$TESTMESSAGETESTMESSAGETESTMESSAGETEST$$";
+
+static void OnReadCompleted(int count,
+ scoped_refptr<net::IOBuffer> io_buffer) {
+ size_t expected_size = arraysize(test_message);
+ EXPECT_EQ((size_t)(count), expected_size);
+ EXPECT_EQ(strncmp(io_buffer->data(), test_message, expected_size), 0);
+}
+
+static void OnSendCompleted(int result) {
+ EXPECT_EQ((size_t)(result), arraysize(test_message));
+}
+
TEST(UDPSocketUnitTest, TestUDPSocketRecvFrom) {
MessageLoopForIO io_loop; // for RecvFrom to do its threaded work.
UDPSocket socket("abcdefghijklmnopqrst");
@@ -41,4 +54,32 @@ TEST(UDPSocketUnitTest, TestUDPSocketRecvFrom) {
socket.RecvFrom(4096, base::Bind(&OnCompleted));
}
+TEST(UDPSocketUnitTest, TestUDPMulticast) {
+ const char* kGroup = "237.132.100.17";
+ MessageLoopForIO io_loop; // for RecvFrom to do its threaded work.
mmenke 2013/04/12 21:07:41 Comments should generally start with a capital.
Bei Zhang 2013/04/15 22:30:26 Done.
+ UDPSocket src("abcdefghijklmnopqrst");
+ UDPSocket dest("abcdefghijklmnopqrst");
+
+ EXPECT_EQ(dest.Bind("0.0.0.0", 13333), 0);
+ EXPECT_EQ(dest.JoinGroup(kGroup), 0);
+ dest.Read(1024, base::Bind(&OnReadCompleted));
+
+ size_t size = arraysize(test_message);
+ scoped_refptr<net::IOBuffer> data =
+ new net::WrappedIOBuffer(test_message);
+ // Setting multicast setting s should work even before connection.
+ EXPECT_NE(src.SetMulticastTimeToLive(-1), 0);
+ EXPECT_EQ(src.SetMulticastTimeToLive(3), 0);
+ EXPECT_EQ(src.SetMulticastTimeToLive(0), 0);
+ EXPECT_EQ(src.SetMulticastLoopbackMode(false), 0);
+ EXPECT_EQ(src.SetMulticastLoopbackMode(true), 0);
+ src.Connect(kGroup, 13333, base::Bind(&OnConnected));
+ EXPECT_NE(src.SetMulticastTimeToLive(-1), 0); // Negative TTL shall fail
mmenke 2013/04/12 21:07:41 Comments should generally end with a period.
mmenke 2013/04/12 21:07:41 2 spaces before comment.
Bei Zhang 2013/04/15 22:30:26 Done.
Bei Zhang 2013/04/15 22:30:26 Done.
+ EXPECT_EQ(src.SetMulticastTimeToLive(3), 0);
+ EXPECT_EQ(src.SetMulticastTimeToLive(0), 0);
+ EXPECT_EQ(src.SetMulticastLoopbackMode(false), 0);
+ EXPECT_EQ(src.SetMulticastLoopbackMode(true), 0);
+ src.SendTo(data, size, kGroup, 13333, base::Bind(&OnSendCompleted));
+}
+
} // namespace extensions

Powered by Google App Engine
This is Rietveld 408576698