| OLD | NEW |
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 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 "ios/web/net/request_tracker_impl.h" | 5 #include "ios/web/net/request_tracker_impl.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/mac/scoped_nsobject.h" | 10 #include "base/mac/scoped_nsobject.h" |
| 11 #include "base/macros.h" | 11 #include "base/macros.h" |
| 12 #include "base/memory/ptr_util.h" | 12 #include "base/memory/ptr_util.h" |
| 13 #include "base/memory/scoped_vector.h" | 13 #include "base/memory/scoped_vector.h" |
| 14 #include "base/message_loop/message_loop.h" | 14 #include "base/message_loop/message_loop.h" |
| 15 #include "base/strings/sys_string_conversions.h" | 15 #include "base/strings/sys_string_conversions.h" |
| 16 #include "ios/web/public/cert_policy.h" | 16 #include "ios/web/public/cert_policy.h" |
| 17 #include "ios/web/public/certificate_policy_cache.h" | 17 #include "ios/web/public/certificate_policy_cache.h" |
| 18 #include "ios/web/public/ssl_status.h" | 18 #include "ios/web/public/ssl_status.h" |
| 19 #include "ios/web/public/test/test_browser_state.h" | 19 #include "ios/web/public/test/test_browser_state.h" |
| 20 #include "ios/web/public/test/test_web_thread.h" | 20 #include "ios/web/public/test/test_web_thread.h" |
| 21 #include "net/base/test_data_directory.h" |
| 21 #include "net/cert/x509_certificate.h" | 22 #include "net/cert/x509_certificate.h" |
| 22 #include "net/http/http_response_headers.h" | 23 #include "net/http/http_response_headers.h" |
| 24 #include "net/test/cert_test_util.h" |
| 23 #include "net/url_request/url_request.h" | 25 #include "net/url_request/url_request.h" |
| 24 #include "net/url_request/url_request_context.h" | 26 #include "net/url_request/url_request_context.h" |
| 25 #include "net/url_request/url_request_job_factory.h" | 27 #include "net/url_request/url_request_job_factory.h" |
| 26 #include "net/url_request/url_request_job_factory_impl.h" | 28 #include "net/url_request/url_request_job_factory_impl.h" |
| 27 #include "net/url_request/url_request_test_job.h" | 29 #include "net/url_request/url_request_test_job.h" |
| 28 #include "net/url_request/url_request_test_util.h" | 30 #include "net/url_request/url_request_test_util.h" |
| 29 #include "testing/gtest/include/gtest/gtest.h" | 31 #include "testing/gtest/include/gtest/gtest.h" |
| 30 #include "testing/gtest_mac.h" | 32 #include "testing/gtest_mac.h" |
| 31 #include "testing/platform_test.h" | 33 #include "testing/platform_test.h" |
| 32 #import "third_party/ocmock/OCMock/OCMock.h" | 34 #import "third_party/ocmock/OCMock/OCMock.h" |
| (...skipping 222 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 255 requests_.push_back( | 257 requests_.push_back( |
| 256 contexts_[i] | 258 contexts_[i] |
| 257 ->CreateRequest(url, net::DEFAULT_PRIORITY, &request_delegate_) | 259 ->CreateRequest(url, net::DEFAULT_PRIORITY, &request_delegate_) |
| 258 .release()); | 260 .release()); |
| 259 | 261 |
| 260 if (secure) { | 262 if (secure) { |
| 261 // Put a valid SSLInfo inside | 263 // Put a valid SSLInfo inside |
| 262 net::HttpResponseInfo* response = | 264 net::HttpResponseInfo* response = |
| 263 const_cast<net::HttpResponseInfo*>(&requests_[i]->response_info()); | 265 const_cast<net::HttpResponseInfo*>(&requests_[i]->response_info()); |
| 264 | 266 |
| 265 response->ssl_info.cert = new net::X509Certificate( | 267 response->ssl_info.cert = net::ImportCertFromFile( |
| 266 "subject", "issuer", | 268 net::GetTestCertsDirectory(), "ok_cert.pem"); |
| 267 base::Time::Now() - base::TimeDelta::FromDays(2), | |
| 268 base::Time::Now() + base::TimeDelta::FromDays(2)); | |
| 269 response->ssl_info.cert_status = 0; // No errors. | 269 response->ssl_info.cert_status = 0; // No errors. |
| 270 response->ssl_info.security_bits = 128; | 270 response->ssl_info.security_bits = 128; |
| 271 | 271 |
| 272 EXPECT_TRUE(requests_[i]->ssl_info().is_valid()); | 272 EXPECT_TRUE(requests_[i]->ssl_info().is_valid()); |
| 273 } | 273 } |
| 274 } | 274 } |
| 275 EXPECT_TRUE(!secure == !requests_[i]->url().SchemeIsCryptographic()); | 275 EXPECT_TRUE(!secure == !requests_[i]->url().SchemeIsCryptographic()); |
| 276 return requests_[i]; | 276 return requests_[i]; |
| 277 } | 277 } |
| 278 | 278 |
| (...skipping 226 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 505 base::Bind(&TwoStartsSSLCallback, | 505 base::Bind(&TwoStartsSSLCallback, |
| 506 &request_0_called)); | 506 &request_0_called)); |
| 507 tracker_->OnSSLCertificateError(GetSecureRequest(1), ssl_info, true, | 507 tracker_->OnSSLCertificateError(GetSecureRequest(1), ssl_info, true, |
| 508 base::Bind(&TwoStartsSSLCallback, | 508 base::Bind(&TwoStartsSSLCallback, |
| 509 &request_1_called)); | 509 &request_1_called)); |
| 510 EXPECT_TRUE(request_0_called); | 510 EXPECT_TRUE(request_0_called); |
| 511 EXPECT_TRUE(request_1_called); | 511 EXPECT_TRUE(request_1_called); |
| 512 } | 512 } |
| 513 | 513 |
| 514 } // namespace | 514 } // namespace |
| OLD | NEW |