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

Side by Side Diff: net/base/address_list_unittest.cc

Issue 118100: Avoid doing concurrent DNS resolves of the same hostname (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Get compiling on mac Created 11 years, 6 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
Property Changes:
Added: svn:eol-style
+ LF
OLDNEW
(Empty)
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "net/base/address_list.h"
6
7 #if defined(OS_WIN)
8 #include <ws2tcpip.h>
9 #include <wspiapi.h> // Needed for Win2k compat.
10 #elif defined(OS_POSIX)
11 #include <netdb.h>
12 #include <sys/socket.h>
13 #endif
14
15 #include "base/string_util.h"
16 #include "net/base/net_util.h"
17 #if defined(OS_WIN)
18 #include "net/base/winsock_init.h"
19 #endif
20 #include "testing/gtest/include/gtest/gtest.h"
21
22 namespace {
23
24 // Use getaddrinfo() to allocate an addrinfo structure.
25 void CreateAddressList(net::AddressList* addrlist, int port) {
26 #if defined(OS_WIN)
27 net::EnsureWinsockInit();
28 #endif
29 std::string portstr = IntToString(port);
30
31 struct addrinfo* result = NULL;
32 struct addrinfo hints = {0};
33 hints.ai_family = AF_UNSPEC;
34 hints.ai_flags = AI_NUMERICHOST;
35 hints.ai_socktype = SOCK_STREAM;
36
37 int err = getaddrinfo("192.168.1.1", portstr.c_str(), &hints, &result);
38 EXPECT_EQ(0, err);
39 addrlist->Adopt(result);
40 }
41
42 TEST(AddressListTest, GetPort) {
43 net::AddressList addrlist;
44 CreateAddressList(&addrlist, 81);
45 EXPECT_EQ(81, addrlist.GetPort());
46
47 addrlist.SetPort(83);
48 EXPECT_EQ(83, addrlist.GetPort());
49 }
50
51 TEST(AddressListTest, Assignment) {
52 net::AddressList addrlist1;
53 CreateAddressList(&addrlist1, 85);
54 EXPECT_EQ(85, addrlist1.GetPort());
55
56 // Should reference the same data as addrlist1 -- so when we change addrlist1
57 // both are changed.
58 net::AddressList addrlist2 = addrlist1;
59 EXPECT_EQ(85, addrlist2.GetPort());
60
61 addrlist1.SetPort(80);
62 EXPECT_EQ(80, addrlist1.GetPort());
63 EXPECT_EQ(80, addrlist2.GetPort());
64 }
65
66 TEST(AddressListTest, Copy) {
67 net::AddressList addrlist1;
68 CreateAddressList(&addrlist1, 85);
69 EXPECT_EQ(85, addrlist1.GetPort());
70
71 net::AddressList addrlist2;
72 addrlist2.Copy(addrlist1.head());
73
74 // addrlist1 is the same as addrlist2 at this point.
75 EXPECT_EQ(85, addrlist1.GetPort());
76 EXPECT_EQ(85, addrlist2.GetPort());
77
78 // Changes to addrlist1 are not reflected in addrlist2.
79 addrlist1.SetPort(70);
80 addrlist2.SetPort(90);
81
82 EXPECT_EQ(70, addrlist1.GetPort());
83 EXPECT_EQ(90, addrlist2.GetPort());
84 }
85
86 } // namespace
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698