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

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

Issue 598071: Really connect to the same server in FTP network transaction. (Closed)
Patch Set: updates Created 10 years, 10 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
« no previous file with comments | « net/base/address_list.cc ('k') | net/base/nss_memio.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 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 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 "net/base/address_list.h" 5 #include "net/base/address_list.h"
6 6
7 #include "base/string_util.h" 7 #include "base/string_util.h"
8 #include "net/base/host_resolver_proc.h" 8 #include "net/base/host_resolver_proc.h"
9 #include "net/base/net_util.h" 9 #include "net/base/net_util.h"
10 #include "net/base/sys_addrinfo.h"
10 #if defined(OS_WIN) 11 #if defined(OS_WIN)
11 #include "net/base/winsock_init.h" 12 #include "net/base/winsock_init.h"
12 #endif 13 #endif
13 #include "testing/gtest/include/gtest/gtest.h" 14 #include "testing/gtest/include/gtest/gtest.h"
14 15
15 namespace { 16 namespace {
16 17
17 // Use getaddrinfo() to allocate an addrinfo structure. 18 // Use getaddrinfo() to allocate an addrinfo structure.
18 void CreateAddressList(net::AddressList* addrlist, int port) { 19 void CreateAddressList(const std::string& hostname,
20 net::AddressList* addrlist, int port) {
19 #if defined(OS_WIN) 21 #if defined(OS_WIN)
20 net::EnsureWinsockInit(); 22 net::EnsureWinsockInit();
21 #endif 23 #endif
22 int rv = SystemHostResolverProc("192.168.1.1", 24 int rv = SystemHostResolverProc(hostname,
23 net::ADDRESS_FAMILY_UNSPECIFIED, 25 net::ADDRESS_FAMILY_UNSPECIFIED,
24 addrlist); 26 addrlist);
25 EXPECT_EQ(0, rv); 27 EXPECT_EQ(0, rv);
26 addrlist->SetPort(port); 28 addrlist->SetPort(port);
27 } 29 }
28 30
31 void CreateLongAddressList(net::AddressList* addrlist, int port) {
32 CreateAddressList("192.168.1.1", addrlist, port);
33 net::AddressList second_list;
34 CreateAddressList("192.168.1.2", &second_list, port);
35 addrlist->Append(second_list.head());
36 }
37
29 TEST(AddressListTest, GetPort) { 38 TEST(AddressListTest, GetPort) {
30 net::AddressList addrlist; 39 net::AddressList addrlist;
31 CreateAddressList(&addrlist, 81); 40 CreateAddressList("192.168.1.1", &addrlist, 81);
32 EXPECT_EQ(81, addrlist.GetPort()); 41 EXPECT_EQ(81, addrlist.GetPort());
33 42
34 addrlist.SetPort(83); 43 addrlist.SetPort(83);
35 EXPECT_EQ(83, addrlist.GetPort()); 44 EXPECT_EQ(83, addrlist.GetPort());
36 } 45 }
37 46
38 TEST(AddressListTest, Assignment) { 47 TEST(AddressListTest, Assignment) {
39 net::AddressList addrlist1; 48 net::AddressList addrlist1;
40 CreateAddressList(&addrlist1, 85); 49 CreateAddressList("192.168.1.1", &addrlist1, 85);
41 EXPECT_EQ(85, addrlist1.GetPort()); 50 EXPECT_EQ(85, addrlist1.GetPort());
42 51
43 // Should reference the same data as addrlist1 -- so when we change addrlist1 52 // Should reference the same data as addrlist1 -- so when we change addrlist1
44 // both are changed. 53 // both are changed.
45 net::AddressList addrlist2 = addrlist1; 54 net::AddressList addrlist2 = addrlist1;
46 EXPECT_EQ(85, addrlist2.GetPort()); 55 EXPECT_EQ(85, addrlist2.GetPort());
47 56
48 addrlist1.SetPort(80); 57 addrlist1.SetPort(80);
49 EXPECT_EQ(80, addrlist1.GetPort()); 58 EXPECT_EQ(80, addrlist1.GetPort());
50 EXPECT_EQ(80, addrlist2.GetPort()); 59 EXPECT_EQ(80, addrlist2.GetPort());
51 } 60 }
52 61
53 TEST(AddressListTest, Copy) { 62 TEST(AddressListTest, CopyRecursive) {
54 net::AddressList addrlist1; 63 net::AddressList addrlist1;
55 CreateAddressList(&addrlist1, 85); 64 CreateLongAddressList(&addrlist1, 85);
56 EXPECT_EQ(85, addrlist1.GetPort()); 65 EXPECT_EQ(85, addrlist1.GetPort());
57 66
58 net::AddressList addrlist2; 67 net::AddressList addrlist2;
59 addrlist2.Copy(addrlist1.head()); 68 addrlist2.Copy(addrlist1.head(), true);
69
70 ASSERT_TRUE(addrlist2.head()->ai_next != NULL);
60 71
61 // addrlist1 is the same as addrlist2 at this point. 72 // addrlist1 is the same as addrlist2 at this point.
62 EXPECT_EQ(85, addrlist1.GetPort()); 73 EXPECT_EQ(85, addrlist1.GetPort());
63 EXPECT_EQ(85, addrlist2.GetPort()); 74 EXPECT_EQ(85, addrlist2.GetPort());
64 75
65 // Changes to addrlist1 are not reflected in addrlist2. 76 // Changes to addrlist1 are not reflected in addrlist2.
66 addrlist1.SetPort(70); 77 addrlist1.SetPort(70);
67 addrlist2.SetPort(90); 78 addrlist2.SetPort(90);
68 79
69 EXPECT_EQ(70, addrlist1.GetPort()); 80 EXPECT_EQ(70, addrlist1.GetPort());
70 EXPECT_EQ(90, addrlist2.GetPort()); 81 EXPECT_EQ(90, addrlist2.GetPort());
71 } 82 }
72 83
84 TEST(AddressListTest, CopyNonRecursive) {
85 net::AddressList addrlist1;
86 CreateLongAddressList(&addrlist1, 85);
87 EXPECT_EQ(85, addrlist1.GetPort());
88
89 net::AddressList addrlist2;
90 addrlist2.Copy(addrlist1.head(), false);
91
92 ASSERT_TRUE(addrlist2.head()->ai_next == NULL);
93
94 // addrlist1 is the same as addrlist2 at this point.
95 EXPECT_EQ(85, addrlist1.GetPort());
96 EXPECT_EQ(85, addrlist2.GetPort());
97
98 // Changes to addrlist1 are not reflected in addrlist2.
99 addrlist1.SetPort(70);
100 addrlist2.SetPort(90);
101
102 EXPECT_EQ(70, addrlist1.GetPort());
103 EXPECT_EQ(90, addrlist2.GetPort());
104 }
105
106 TEST(AddressListTest, Append) {
107 net::AddressList addrlist1;
108 CreateAddressList("192.168.1.1", &addrlist1, 11);
109 EXPECT_EQ(11, addrlist1.GetPort());
110 net::AddressList addrlist2;
111 CreateAddressList("192.168.1.2", &addrlist2, 12);
112 EXPECT_EQ(12, addrlist2.GetPort());
113
114 ASSERT_TRUE(addrlist1.head()->ai_next == NULL);
115 addrlist1.Append(addrlist2.head());
116 ASSERT_TRUE(addrlist1.head()->ai_next != NULL);
117
118 net::AddressList addrlist3;
119 addrlist3.Copy(addrlist1.head()->ai_next, false);
120 EXPECT_EQ(12, addrlist3.GetPort());
121 }
122
73 } // namespace 123 } // namespace
OLDNEW
« no previous file with comments | « net/base/address_list.cc ('k') | net/base/nss_memio.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698