OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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 "base/bind.h" | 5 #include "base/bind.h" |
6 #include "base/files/file_path.h" | 6 #include "base/files/file_path.h" |
7 #include "base/synchronization/waitable_event.h" | 7 #include "base/synchronization/waitable_event.h" |
8 #include "chrome/browser/profiles/profile.h" | 8 #include "chrome/browser/profiles/profile.h" |
9 #include "chrome/browser/ssl/ssl_client_auth_requestor_mock.h" | 9 #include "chrome/browser/ssl/ssl_client_auth_requestor_mock.h" |
10 #include "chrome/browser/ui/browser.h" | 10 #include "chrome/browser/ui/browser.h" |
11 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 11 #include "chrome/browser/ui/tabs/tab_strip_model.h" |
12 #include "chrome/browser/ui/views/ssl_client_certificate_selector.h" | 12 #include "chrome/browser/ui/views/ssl_client_certificate_selector.h" |
13 #include "chrome/test/base/in_process_browser_test.h" | 13 #include "chrome/test/base/in_process_browser_test.h" |
14 #include "chrome/test/base/interactive_test_utils.h" | 14 #include "chrome/test/base/interactive_test_utils.h" |
15 #include "chrome/test/base/ui_test_utils.h" | 15 #include "chrome/test/base/ui_test_utils.h" |
| 16 #include "content/public/browser/client_certificate_delegate.h" |
16 #include "content/public/browser/web_contents.h" | 17 #include "content/public/browser/web_contents.h" |
17 #include "content/public/test/browser_test_utils.h" | 18 #include "content/public/test/browser_test_utils.h" |
18 #include "net/base/request_priority.h" | 19 #include "net/base/request_priority.h" |
19 #include "net/base/test_data_directory.h" | 20 #include "net/base/test_data_directory.h" |
20 #include "net/cert/x509_certificate.h" | 21 #include "net/cert/x509_certificate.h" |
21 #include "net/http/http_transaction_factory.h" | 22 #include "net/http/http_transaction_factory.h" |
22 #include "net/ssl/ssl_cert_request_info.h" | 23 #include "net/ssl/ssl_cert_request_info.h" |
23 #include "net/test/cert_test_util.h" | 24 #include "net/test/cert_test_util.h" |
24 #include "net/url_request/url_request.h" | 25 #include "net/url_request/url_request.h" |
25 #include "net/url_request/url_request_context.h" | 26 #include "net/url_request/url_request_context.h" |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
66 BrowserThread::PostTask( | 67 BrowserThread::PostTask( |
67 BrowserThread::IO, FROM_HERE, | 68 BrowserThread::IO, FROM_HERE, |
68 base::Bind(&SSLClientCertificateSelectorTest::SetUpOnIOThread, this)); | 69 base::Bind(&SSLClientCertificateSelectorTest::SetUpOnIOThread, this)); |
69 | 70 |
70 io_loop_finished_event_.Wait(); | 71 io_loop_finished_event_.Wait(); |
71 | 72 |
72 content::WaitForLoadStop( | 73 content::WaitForLoadStop( |
73 browser()->tab_strip_model()->GetActiveWebContents()); | 74 browser()->tab_strip_model()->GetActiveWebContents()); |
74 selector_ = new SSLClientCertificateSelector( | 75 selector_ = new SSLClientCertificateSelector( |
75 browser()->tab_strip_model()->GetActiveWebContents(), | 76 browser()->tab_strip_model()->GetActiveWebContents(), |
76 auth_requestor_->cert_request_info_, | 77 auth_requestor_->cert_request_info_, auth_requestor_->CreateDelegate()); |
77 base::Bind(&SSLClientAuthRequestorMock::CertificateSelected, | |
78 auth_requestor_)); | |
79 selector_->Init(); | 78 selector_->Init(); |
80 | 79 |
81 EXPECT_EQ(mit_davidben_cert_.get(), selector_->GetSelectedCert()); | 80 EXPECT_EQ(mit_davidben_cert_.get(), selector_->GetSelectedCert()); |
82 } | 81 } |
83 | 82 |
84 virtual void SetUpOnIOThread() { | 83 virtual void SetUpOnIOThread() { |
85 url_request_ = MakeURLRequest(url_request_context_getter_.get()).release(); | 84 url_request_ = MakeURLRequest(url_request_context_getter_.get()).release(); |
86 | 85 |
87 auth_requestor_ = new StrictMock<SSLClientAuthRequestorMock>( | 86 auth_requestor_ = new StrictMock<SSLClientAuthRequestorMock>( |
88 url_request_, | 87 url_request_, |
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
154 AddTabAtIndex(2, GURL("about:blank"), ui::PAGE_TRANSITION_LINK); | 153 AddTabAtIndex(2, GURL("about:blank"), ui::PAGE_TRANSITION_LINK); |
155 ASSERT_TRUE(NULL != browser()->tab_strip_model()->GetWebContentsAt(0)); | 154 ASSERT_TRUE(NULL != browser()->tab_strip_model()->GetWebContentsAt(0)); |
156 ASSERT_TRUE(NULL != browser()->tab_strip_model()->GetWebContentsAt(1)); | 155 ASSERT_TRUE(NULL != browser()->tab_strip_model()->GetWebContentsAt(1)); |
157 ASSERT_TRUE(NULL != browser()->tab_strip_model()->GetWebContentsAt(2)); | 156 ASSERT_TRUE(NULL != browser()->tab_strip_model()->GetWebContentsAt(2)); |
158 content::WaitForLoadStop(browser()->tab_strip_model()->GetWebContentsAt(1)); | 157 content::WaitForLoadStop(browser()->tab_strip_model()->GetWebContentsAt(1)); |
159 content::WaitForLoadStop(browser()->tab_strip_model()->GetWebContentsAt(2)); | 158 content::WaitForLoadStop(browser()->tab_strip_model()->GetWebContentsAt(2)); |
160 | 159 |
161 selector_1_ = new SSLClientCertificateSelector( | 160 selector_1_ = new SSLClientCertificateSelector( |
162 browser()->tab_strip_model()->GetWebContentsAt(1), | 161 browser()->tab_strip_model()->GetWebContentsAt(1), |
163 auth_requestor_1_->cert_request_info_, | 162 auth_requestor_1_->cert_request_info_, |
164 base::Bind(&SSLClientAuthRequestorMock::CertificateSelected, | 163 auth_requestor_1_->CreateDelegate()); |
165 auth_requestor_1_)); | |
166 selector_1_->Init(); | 164 selector_1_->Init(); |
167 selector_2_ = new SSLClientCertificateSelector( | 165 selector_2_ = new SSLClientCertificateSelector( |
168 browser()->tab_strip_model()->GetWebContentsAt(2), | 166 browser()->tab_strip_model()->GetWebContentsAt(2), |
169 auth_requestor_2_->cert_request_info_, | 167 auth_requestor_2_->cert_request_info_, |
170 base::Bind(&SSLClientAuthRequestorMock::CertificateSelected, | 168 auth_requestor_2_->CreateDelegate()); |
171 auth_requestor_2_)); | |
172 selector_2_->Init(); | 169 selector_2_->Init(); |
173 | 170 |
174 EXPECT_EQ(2, browser()->tab_strip_model()->active_index()); | 171 EXPECT_EQ(2, browser()->tab_strip_model()->active_index()); |
175 EXPECT_EQ(mit_davidben_cert_.get(), selector_1_->GetSelectedCert()); | 172 EXPECT_EQ(mit_davidben_cert_.get(), selector_1_->GetSelectedCert()); |
176 EXPECT_EQ(mit_davidben_cert_.get(), selector_2_->GetSelectedCert()); | 173 EXPECT_EQ(mit_davidben_cert_.get(), selector_2_->GetSelectedCert()); |
177 } | 174 } |
178 | 175 |
179 void SetUpOnIOThread() override { | 176 void SetUpOnIOThread() override { |
180 url_request_1_ = | 177 url_request_1_ = |
181 MakeURLRequest(url_request_context_getter_.get()).release(); | 178 MakeURLRequest(url_request_context_getter_.get()).release(); |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
230 void SetUpOnMainThread() override { | 227 void SetUpOnMainThread() override { |
231 browser_1_ = CreateIncognitoBrowser(); | 228 browser_1_ = CreateIncognitoBrowser(); |
232 url_request_context_getter_1_ = browser_1_->profile()->GetRequestContext(); | 229 url_request_context_getter_1_ = browser_1_->profile()->GetRequestContext(); |
233 | 230 |
234 // Also calls SetUpOnIOThread. | 231 // Also calls SetUpOnIOThread. |
235 SSLClientCertificateSelectorTest::SetUpOnMainThread(); | 232 SSLClientCertificateSelectorTest::SetUpOnMainThread(); |
236 | 233 |
237 selector_1_ = new SSLClientCertificateSelector( | 234 selector_1_ = new SSLClientCertificateSelector( |
238 browser_1_->tab_strip_model()->GetActiveWebContents(), | 235 browser_1_->tab_strip_model()->GetActiveWebContents(), |
239 auth_requestor_1_->cert_request_info_, | 236 auth_requestor_1_->cert_request_info_, |
240 base::Bind(&SSLClientAuthRequestorMock::CertificateSelected, | 237 auth_requestor_1_->CreateDelegate()); |
241 auth_requestor_1_)); | |
242 selector_1_->Init(); | 238 selector_1_->Init(); |
243 | 239 |
244 EXPECT_EQ(mit_davidben_cert_.get(), selector_1_->GetSelectedCert()); | 240 EXPECT_EQ(mit_davidben_cert_.get(), selector_1_->GetSelectedCert()); |
245 } | 241 } |
246 | 242 |
247 void SetUpOnIOThread() override { | 243 void SetUpOnIOThread() override { |
248 url_request_1_ = | 244 url_request_1_ = |
249 MakeURLRequest(url_request_context_getter_1_.get()).release(); | 245 MakeURLRequest(url_request_context_getter_1_.get()).release(); |
250 | 246 |
251 auth_requestor_1_ = new StrictMock<SSLClientAuthRequestorMock>( | 247 auth_requestor_1_ = new StrictMock<SSLClientAuthRequestorMock>( |
(...skipping 24 matching lines...) Expand all Loading... |
276 | 272 |
277 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) && defined(USE_AURA) | 273 #if defined(OS_LINUX) && !defined(OS_CHROMEOS) && defined(USE_AURA) |
278 // TODO(erg): linux_aura bringup: http://crbug.com/163931 | 274 // TODO(erg): linux_aura bringup: http://crbug.com/163931 |
279 #define MAYBE_SelectNone DISABLED_SelectNone | 275 #define MAYBE_SelectNone DISABLED_SelectNone |
280 #else | 276 #else |
281 #define MAYBE_SelectNone SelectNone | 277 #define MAYBE_SelectNone SelectNone |
282 #endif | 278 #endif |
283 | 279 |
284 | 280 |
285 IN_PROC_BROWSER_TEST_F(SSLClientCertificateSelectorTest, MAYBE_SelectNone) { | 281 IN_PROC_BROWSER_TEST_F(SSLClientCertificateSelectorTest, MAYBE_SelectNone) { |
286 EXPECT_CALL(*auth_requestor_.get(), CertificateSelected(NULL)); | 282 EXPECT_CALL(*auth_requestor_.get(), CancelCertificateSelection()); |
287 | 283 |
288 // Let the mock get checked on destruction. | 284 // Let the mock get checked on destruction. |
289 } | 285 } |
290 | 286 |
291 // http://crbug.com/121007 | 287 // http://crbug.com/121007 |
292 IN_PROC_BROWSER_TEST_F(SSLClientCertificateSelectorTest, DISABLED_Escape) { | 288 IN_PROC_BROWSER_TEST_F(SSLClientCertificateSelectorTest, DISABLED_Escape) { |
293 EXPECT_CALL(*auth_requestor_.get(), CertificateSelected(NULL)); | 289 EXPECT_CALL(*auth_requestor_.get(), CertificateSelected(NULL)); |
294 | 290 |
295 EXPECT_TRUE(ui_test_utils::SendKeyPressSync( | 291 EXPECT_TRUE(ui_test_utils::SendKeyPressSync( |
296 browser(), ui::VKEY_ESCAPE, false, false, false, false)); | 292 browser(), ui::VKEY_ESCAPE, false, false, false, false)); |
(...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
386 EXPECT_TRUE(ui_test_utils::SendKeyPressSync( | 382 EXPECT_TRUE(ui_test_utils::SendKeyPressSync( |
387 browser_1_, ui::VKEY_RETURN, false, false, false, false)); | 383 browser_1_, ui::VKEY_RETURN, false, false, false, false)); |
388 | 384 |
389 Mock::VerifyAndClear(auth_requestor_.get()); | 385 Mock::VerifyAndClear(auth_requestor_.get()); |
390 Mock::VerifyAndClear(auth_requestor_1_.get()); | 386 Mock::VerifyAndClear(auth_requestor_1_.get()); |
391 | 387 |
392 // Now let the default selection for auth_requestor_ mock get checked on | 388 // Now let the default selection for auth_requestor_ mock get checked on |
393 // destruction. | 389 // destruction. |
394 EXPECT_CALL(*auth_requestor_.get(), CertificateSelected(NULL)); | 390 EXPECT_CALL(*auth_requestor_.get(), CertificateSelected(NULL)); |
395 } | 391 } |
OLD | NEW |