Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 |
| OLD | NEW |