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

Side by Side Diff: net/http/disk_cache_based_quic_server_info_unittest.cc

Issue 192583004: QUIC - use QuicSessionKey tuple (host, port, is_https) instead of server_hostname (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix comments from Patch set 1 and 3 and merge with TOT Created 6 years, 9 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/http/disk_cache_based_quic_server_info.h" 5 #include "net/http/disk_cache_based_quic_server_info.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/bind_helpers.h" 8 #include "base/bind_helpers.h"
9 #include "base/compiler_specific.h" 9 #include "base/compiler_specific.h"
10 #include "base/message_loop/message_loop.h" 10 #include "base/message_loop/message_loop.h"
11 #include "net/base/host_port_pair.h"
11 #include "net/base/net_errors.h" 12 #include "net/base/net_errors.h"
12 #include "net/http/mock_http_cache.h" 13 #include "net/http/mock_http_cache.h"
13 #include "net/quic/crypto/quic_server_info.h" 14 #include "net/quic/crypto/quic_server_info.h"
14 #include "testing/gtest/include/gtest/gtest.h" 15 #include "testing/gtest/include/gtest/gtest.h"
15 16
16 namespace { 17 namespace {
17 18
18 // This is an empty transaction, needed to register the URL and the test mode. 19 // This is an empty transaction, needed to register the URL and the test mode.
19 const MockTransaction kHostInfoTransaction = { 20 const MockTransaction kHostInfoTransaction1 = {
20 "quicserverinfo:https://www.google.com", 21 "quicserverinfo:https://www.google.com:443",
21 "", 22 "",
22 base::Time(), 23 base::Time(),
23 "", 24 "",
25 net::LOAD_NORMAL,
26 "",
27 "",
28 base::Time(),
29 "",
30 TEST_MODE_NORMAL,
31 NULL,
32 0
33 };
34
35 const MockTransaction kHostInfoTransaction2 = {
36 "quicserverinfo:https://www.google.com:80",
37 "",
38 base::Time(),
39 "",
24 net::LOAD_NORMAL, 40 net::LOAD_NORMAL,
25 "", 41 "",
26 "", 42 "",
27 base::Time(), 43 base::Time(),
28 "", 44 "",
29 TEST_MODE_NORMAL, 45 TEST_MODE_NORMAL,
30 NULL, 46 NULL,
31 0 47 0
32 }; 48 };
33 49
34 // Tests that we can delete a DiskCacheBasedQuicServerInfo object in a 50 // Tests that we can delete a DiskCacheBasedQuicServerInfo object in a
35 // completion callback for DiskCacheBasedQuicServerInfo::WaitForDataReady. 51 // completion callback for DiskCacheBasedQuicServerInfo::WaitForDataReady.
36 TEST(DiskCacheBasedQuicServerInfo, DeleteInCallback) { 52 TEST(DiskCacheBasedQuicServerInfo, DeleteInCallback) {
37 // Use the blocking mock backend factory to force asynchronous completion 53 // Use the blocking mock backend factory to force asynchronous completion
38 // of quic_server_info->WaitForDataReady(), so that the callback will run. 54 // of quic_server_info->WaitForDataReady(), so that the callback will run.
39 MockBlockingBackendFactory* factory = new MockBlockingBackendFactory(); 55 MockBlockingBackendFactory* factory = new MockBlockingBackendFactory();
40 MockHttpCache cache(factory); 56 MockHttpCache cache(factory);
57 net::HostPortPair host_port_pair("https://www.verisign.com", 443);
wtc 2014/03/11 01:41:39 IMPORTANT: the HostPortPair constructor you are us
ramant (doing other things) 2014/03/13 01:50:12 Done.
41 scoped_ptr<net::QuicServerInfo> quic_server_info( 58 scoped_ptr<net::QuicServerInfo> quic_server_info(
42 new net::DiskCacheBasedQuicServerInfo("https://www.verisign.com", 59 new net::DiskCacheBasedQuicServerInfo(host_port_pair,
43 cache.http_cache())); 60 cache.http_cache()));
44 quic_server_info->Start(); 61 quic_server_info->Start();
45 net::TestCompletionCallback callback; 62 net::TestCompletionCallback callback;
46 int rv = quic_server_info->WaitForDataReady(callback.callback()); 63 int rv = quic_server_info->WaitForDataReady(callback.callback());
47 EXPECT_EQ(net::ERR_IO_PENDING, rv); 64 EXPECT_EQ(net::ERR_IO_PENDING, rv);
48 // Now complete the backend creation and let the callback run. 65 // Now complete the backend creation and let the callback run.
49 factory->FinishCreation(); 66 factory->FinishCreation();
50 EXPECT_EQ(net::OK, callback.GetResult(rv)); 67 EXPECT_EQ(net::OK, callback.GetResult(rv));
51 } 68 }
52 69
53 // Tests the basic logic of storing, retrieving and updating data. 70 // Tests the basic logic of storing, retrieving and updating data.
54 TEST(DiskCacheBasedQuicServerInfo, Update) { 71 TEST(DiskCacheBasedQuicServerInfo, Update) {
55 MockHttpCache cache; 72 MockHttpCache cache;
56 AddMockTransaction(&kHostInfoTransaction); 73 AddMockTransaction(&kHostInfoTransaction1);
57 net::TestCompletionCallback callback; 74 net::TestCompletionCallback callback;
58 75
76 net::HostPortPair host_port_pair("https://www.google.com", 443);
59 scoped_ptr<net::QuicServerInfo> quic_server_info( 77 scoped_ptr<net::QuicServerInfo> quic_server_info(
60 new net::DiskCacheBasedQuicServerInfo("https://www.google.com", 78 new net::DiskCacheBasedQuicServerInfo(host_port_pair,
61 cache.http_cache())); 79 cache.http_cache()));
62 quic_server_info->Start(); 80 quic_server_info->Start();
63 int rv = quic_server_info->WaitForDataReady(callback.callback()); 81 int rv = quic_server_info->WaitForDataReady(callback.callback());
64 EXPECT_EQ(net::OK, callback.GetResult(rv)); 82 EXPECT_EQ(net::OK, callback.GetResult(rv));
65 83
66 net::QuicServerInfo::State* state = quic_server_info->mutable_state(); 84 net::QuicServerInfo::State* state = quic_server_info->mutable_state();
67 EXPECT_TRUE(state->certs.empty()); 85 EXPECT_TRUE(state->certs.empty());
68 const string server_config_a = "server_config_a"; 86 const string server_config_a = "server_config_a";
69 const string source_address_token_a = "source_address_token_a"; 87 const string source_address_token_a = "source_address_token_a";
70 const string server_config_sig_a = "server_config_sig_a"; 88 const string server_config_sig_a = "server_config_sig_a";
71 const string cert_a = "cert_a"; 89 const string cert_a = "cert_a";
72 const string cert_b = "cert_b"; 90 const string cert_b = "cert_b";
73 91
74 state->server_config = server_config_a; 92 state->server_config = server_config_a;
75 state->source_address_token = source_address_token_a; 93 state->source_address_token = source_address_token_a;
76 state->server_config_sig = server_config_sig_a; 94 state->server_config_sig = server_config_sig_a;
77 state->certs.push_back(cert_a); 95 state->certs.push_back(cert_a);
78 quic_server_info->Persist(); 96 quic_server_info->Persist();
79 97
80 // Wait until Persist() does the work. 98 // Wait until Persist() does the work.
81 base::MessageLoop::current()->RunUntilIdle(); 99 base::MessageLoop::current()->RunUntilIdle();
82 100
83 // Open the stored QuicServerInfo. 101 // Open the stored QuicServerInfo.
84 quic_server_info.reset( 102 quic_server_info.reset(
85 new net::DiskCacheBasedQuicServerInfo("https://www.google.com", 103 new net::DiskCacheBasedQuicServerInfo(host_port_pair,
86 cache.http_cache())); 104 cache.http_cache()));
87 quic_server_info->Start(); 105 quic_server_info->Start();
88 rv = quic_server_info->WaitForDataReady(callback.callback()); 106 rv = quic_server_info->WaitForDataReady(callback.callback());
89 EXPECT_EQ(net::OK, callback.GetResult(rv)); 107 EXPECT_EQ(net::OK, callback.GetResult(rv));
90 108
91 // And now update the data. 109 // And now update the data.
92 state = quic_server_info->mutable_state(); 110 state = quic_server_info->mutable_state();
93 state->certs.push_back(cert_b); 111 state->certs.push_back(cert_b);
94 112
95 // Fail instead of DCHECKing double creates. 113 // Fail instead of DCHECKing double creates.
96 cache.disk_cache()->set_double_create_check(false); 114 cache.disk_cache()->set_double_create_check(false);
97 quic_server_info->Persist(); 115 quic_server_info->Persist();
98 base::MessageLoop::current()->RunUntilIdle(); 116 base::MessageLoop::current()->RunUntilIdle();
99 117
100 // Verify that the state was updated. 118 // Verify that the state was updated.
101 quic_server_info.reset( 119 quic_server_info.reset(
102 new net::DiskCacheBasedQuicServerInfo("https://www.google.com", 120 new net::DiskCacheBasedQuicServerInfo(host_port_pair,
103 cache.http_cache())); 121 cache.http_cache()));
104 quic_server_info->Start(); 122 quic_server_info->Start();
105 rv = quic_server_info->WaitForDataReady(callback.callback()); 123 rv = quic_server_info->WaitForDataReady(callback.callback());
106 EXPECT_EQ(net::OK, callback.GetResult(rv)); 124 EXPECT_EQ(net::OK, callback.GetResult(rv));
107 125
108 const net::QuicServerInfo::State& state1 = quic_server_info->state(); 126 const net::QuicServerInfo::State& state1 = quic_server_info->state();
109 EXPECT_TRUE(quic_server_info->IsDataReady()); 127 EXPECT_TRUE(quic_server_info->IsDataReady());
110 EXPECT_EQ(server_config_a, state1.server_config); 128 EXPECT_EQ(server_config_a, state1.server_config);
111 EXPECT_EQ(source_address_token_a, state1.source_address_token); 129 EXPECT_EQ(source_address_token_a, state1.source_address_token);
112 EXPECT_EQ(server_config_sig_a, state1.server_config_sig); 130 EXPECT_EQ(server_config_sig_a, state1.server_config_sig);
113 EXPECT_EQ(2U, state1.certs.size()); 131 EXPECT_EQ(2U, state1.certs.size());
114 EXPECT_EQ(cert_a, state1.certs[0]); 132 EXPECT_EQ(cert_a, state1.certs[0]);
115 EXPECT_EQ(cert_b, state1.certs[1]); 133 EXPECT_EQ(cert_b, state1.certs[1]);
116 134
117 RemoveMockTransaction(&kHostInfoTransaction); 135 RemoveMockTransaction(&kHostInfoTransaction1);
136 }
137
138 // Test that demonstrates different info is returned when the ports differ.
139 TEST(DiskCacheBasedQuicServerInfo, UpdateDifferentPorts) {
140 MockHttpCache cache;
141 AddMockTransaction(&kHostInfoTransaction1);
142 AddMockTransaction(&kHostInfoTransaction2);
143 net::TestCompletionCallback callback;
144
145 // Persist data for port 443.
146 net::HostPortPair host_port_pair1("https://www.google.com", 443);
147 scoped_ptr<net::QuicServerInfo> quic_server_info1(
148 new net::DiskCacheBasedQuicServerInfo(host_port_pair1,
149 cache.http_cache()));
150 quic_server_info1->Start();
151 int rv = quic_server_info1->WaitForDataReady(callback.callback());
152 EXPECT_EQ(net::OK, callback.GetResult(rv));
153
154 net::QuicServerInfo::State* state1 = quic_server_info1->mutable_state();
155 EXPECT_TRUE(state1->certs.empty());
156 const string server_config_a = "server_config_a";
157 const string source_address_token_a = "source_address_token_a";
158 const string server_config_sig_a = "server_config_sig_a";
159 const string cert_a = "cert_a";
160
161 state1->server_config = server_config_a;
162 state1->source_address_token = source_address_token_a;
163 state1->server_config_sig = server_config_sig_a;
164 state1->certs.push_back(cert_a);
165 quic_server_info1->Persist();
166
167 // Wait until Persist() does the work.
168 base::MessageLoop::current()->RunUntilIdle();
169
170 // Persist data for port 80.
171 net::HostPortPair host_port_pair2("https://www.google.com", 80);
172 scoped_ptr<net::QuicServerInfo> quic_server_info2(
173 new net::DiskCacheBasedQuicServerInfo(host_port_pair2,
174 cache.http_cache()));
175 quic_server_info2->Start();
176 rv = quic_server_info2->WaitForDataReady(callback.callback());
177 EXPECT_EQ(net::OK, callback.GetResult(rv));
178
179 net::QuicServerInfo::State* state2 = quic_server_info2->mutable_state();
180 EXPECT_TRUE(state2->certs.empty());
181 const string server_config_b = "server_config_b";
182 const string source_address_token_b = "source_address_token_b";
183 const string server_config_sig_b = "server_config_sig_b";
184 const string cert_b = "cert_b";
185
186 state2->server_config = server_config_b;
187 state2->source_address_token = source_address_token_b;
188 state2->server_config_sig = server_config_sig_b;
189 state2->certs.push_back(cert_b);
190 quic_server_info2->Persist();
191
192 // Wait until Persist() does the work.
193 base::MessageLoop::current()->RunUntilIdle();
194
195 // Verify the stored QuicServerInfo for port 443.
196 scoped_ptr<net::QuicServerInfo> quic_server_info(
197 new net::DiskCacheBasedQuicServerInfo(host_port_pair1,
198 cache.http_cache()));
199 quic_server_info->Start();
200 rv = quic_server_info->WaitForDataReady(callback.callback());
201 EXPECT_EQ(net::OK, callback.GetResult(rv));
202
203 const net::QuicServerInfo::State& state_a = quic_server_info->state();
204 EXPECT_TRUE(quic_server_info->IsDataReady());
205 EXPECT_EQ(server_config_a, state_a.server_config);
206 EXPECT_EQ(source_address_token_a, state_a.source_address_token);
207 EXPECT_EQ(server_config_sig_a, state_a.server_config_sig);
208 EXPECT_EQ(1U, state_a.certs.size());
209 EXPECT_EQ(cert_a, state_a.certs[0]);
210
211 // Verify the stored QuicServerInfo for port 80.
212 quic_server_info.reset(
213 new net::DiskCacheBasedQuicServerInfo(host_port_pair2,
214 cache.http_cache()));
215 quic_server_info->Start();
216 rv = quic_server_info->WaitForDataReady(callback.callback());
217 EXPECT_EQ(net::OK, callback.GetResult(rv));
218
219 const net::QuicServerInfo::State& state_b = quic_server_info->state();
220 EXPECT_TRUE(quic_server_info->IsDataReady());
221 EXPECT_EQ(server_config_b, state_b.server_config);
222 EXPECT_EQ(source_address_token_b, state_b.source_address_token);
223 EXPECT_EQ(server_config_sig_b, state_b.server_config_sig);
224 EXPECT_EQ(1U, state_b.certs.size());
225 EXPECT_EQ(cert_b, state_b.certs[0]);
226
227 RemoveMockTransaction(&kHostInfoTransaction2);
228 RemoveMockTransaction(&kHostInfoTransaction1);
118 } 229 }
119 230
120 } // namespace 231 } // namespace
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698