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

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: 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 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(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.
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
35 static void OnReadCompleted(int count,
36 scoped_refptr<net::IOBuffer> io_buffer) {
37 size_t expected_size = arraysize(test_message);
38 EXPECT_EQ((size_t)(count), expected_size);
39 EXPECT_EQ(strncmp(io_buffer->data(), test_message, expected_size), 0);
40 }
41
42 static void OnSendCompleted(int result) {
43 EXPECT_EQ((size_t)(result), arraysize(test_message));
44 }
45
33 TEST(UDPSocketUnitTest, TestUDPSocketRecvFrom) { 46 TEST(UDPSocketUnitTest, TestUDPSocketRecvFrom) {
34 MessageLoopForIO io_loop; // for RecvFrom to do its threaded work. 47 MessageLoopForIO io_loop; // for RecvFrom to do its threaded work.
35 UDPSocket socket("abcdefghijklmnopqrst"); 48 UDPSocket socket("abcdefghijklmnopqrst");
36 49
37 // Confirm that we can call two RecvFroms in quick succession without 50 // Confirm that we can call two RecvFroms in quick succession without
38 // triggering crbug.com/146606. 51 // triggering crbug.com/146606.
39 socket.Connect("127.0.0.1", 40000, base::Bind(&OnConnected)); 52 socket.Connect("127.0.0.1", 40000, base::Bind(&OnConnected));
40 socket.RecvFrom(4096, base::Bind(&OnCompleted)); 53 socket.RecvFrom(4096, base::Bind(&OnCompleted));
41 socket.RecvFrom(4096, base::Bind(&OnCompleted)); 54 socket.RecvFrom(4096, base::Bind(&OnCompleted));
42 } 55 }
43 56
57 TEST(UDPSocketUnitTest, TestUDPMulticast) {
58 const char* kGroup = "237.132.100.17";
59 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.
60 UDPSocket src("abcdefghijklmnopqrst");
61 UDPSocket dest("abcdefghijklmnopqrst");
62
63 EXPECT_EQ(dest.Bind("0.0.0.0", 13333), 0);
64 EXPECT_EQ(dest.JoinGroup(kGroup), 0);
65 dest.Read(1024, base::Bind(&OnReadCompleted));
66
67 size_t size = arraysize(test_message);
68 scoped_refptr<net::IOBuffer> data =
69 new net::WrappedIOBuffer(test_message);
70 // Setting multicast setting s should work even before connection.
71 EXPECT_NE(src.SetMulticastTimeToLive(-1), 0);
72 EXPECT_EQ(src.SetMulticastTimeToLive(3), 0);
73 EXPECT_EQ(src.SetMulticastTimeToLive(0), 0);
74 EXPECT_EQ(src.SetMulticastLoopbackMode(false), 0);
75 EXPECT_EQ(src.SetMulticastLoopbackMode(true), 0);
76 src.Connect(kGroup, 13333, base::Bind(&OnConnected));
77 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.
78 EXPECT_EQ(src.SetMulticastTimeToLive(3), 0);
79 EXPECT_EQ(src.SetMulticastTimeToLive(0), 0);
80 EXPECT_EQ(src.SetMulticastLoopbackMode(false), 0);
81 EXPECT_EQ(src.SetMulticastLoopbackMode(true), 0);
82 src.SendTo(data, size, kGroup, 13333, base::Bind(&OnSendCompleted));
83 }
84
44 } // namespace extensions 85 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698