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

Side by Side Diff: android_webview/native/aw_contents_client_bridge_unittest.cc

Issue 859213006: Cancel client auth requests when not promptable. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@client-auth-cancel-1
Patch Set: worker_common.js was missing a license header (also a rebase) Created 5 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
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 "android_webview/native/aw_contents_client_bridge.h" 5 #include "android_webview/native/aw_contents_client_bridge.h"
6 6
7 #include "base/android/jni_android.h" 7 #include "base/android/jni_android.h"
8 #include "base/android/jni_array.h" 8 #include "base/android/jni_array.h"
9 #include "base/android/scoped_java_ref.h" 9 #include "base/android/scoped_java_ref.h"
10 #include "base/bind.h" 10 #include "base/bind.h"
11 #include "base/macros.h"
11 #include "base/memory/scoped_ptr.h" 12 #include "base/memory/scoped_ptr.h"
12 #include "base/run_loop.h" 13 #include "base/run_loop.h"
14 #include "content/public/browser/client_certificate_delegate.h"
13 #include "content/public/test/test_browser_thread_bundle.h" 15 #include "content/public/test/test_browser_thread_bundle.h"
14 #include "jni/MockAwContentsClientBridge_jni.h" 16 #include "jni/MockAwContentsClientBridge_jni.h"
15 #include "net/android/net_jni_registrar.h" 17 #include "net/android/net_jni_registrar.h"
16 #include "net/ssl/ssl_cert_request_info.h" 18 #include "net/ssl/ssl_cert_request_info.h"
17 #include "testing/gmock/include/gmock/gmock.h" 19 #include "testing/gmock/include/gmock/gmock.h"
18 #include "testing/gtest/include/gtest/gtest.h" 20 #include "testing/gtest/include/gtest/gtest.h"
19 21
20 22
21 using base::android::AttachCurrentThread; 23 using base::android::AttachCurrentThread;
22 using base::android::ScopedJavaLocalRef; 24 using base::android::ScopedJavaLocalRef;
23 using net::SSLCertRequestInfo; 25 using net::SSLCertRequestInfo;
24 using net::SSLClientCertType; 26 using net::SSLClientCertType;
25 using net::X509Certificate; 27 using net::X509Certificate;
26 using testing::NotNull; 28 using testing::NotNull;
27 using testing::Test; 29 using testing::Test;
28 30
29 namespace android_webview { 31 namespace android_webview {
30 32
31 namespace { 33 namespace {
32 34
33 // Tests the android_webview contents client bridge. 35 // Tests the android_webview contents client bridge.
34 class AwContentsClientBridgeTest : public Test { 36 class AwContentsClientBridgeTest : public Test {
35 public: 37 public:
36 typedef AwContentsClientBridge::SelectCertificateCallback
37 SelectCertificateCallback;
38
39 AwContentsClientBridgeTest() { } 38 AwContentsClientBridgeTest() { }
40 39
41 // Callback method called when a cert is selected. 40 // Callback method called when a cert is selected.
42 void CertSelected(X509Certificate* cert); 41 void CertSelected(X509Certificate* cert);
43 protected: 42 protected:
44 void SetUp() override; 43 void SetUp() override;
45 void TestCertType(SSLClientCertType type, const std::string& expected_name); 44 void TestCertType(SSLClientCertType type, const std::string& expected_name);
46 // Create the TestBrowserThreads. Just instantiate the member variable. 45 // Create the TestBrowserThreads. Just instantiate the member variable.
47 content::TestBrowserThreadBundle thread_bundle_; 46 content::TestBrowserThreadBundle thread_bundle_;
48 base::android::ScopedJavaGlobalRef<jobject> jbridge_; 47 base::android::ScopedJavaGlobalRef<jobject> jbridge_;
49 scoped_ptr<AwContentsClientBridge> bridge_; 48 scoped_ptr<AwContentsClientBridge> bridge_;
50 scoped_refptr<SSLCertRequestInfo> cert_request_info_; 49 scoped_refptr<SSLCertRequestInfo> cert_request_info_;
51 X509Certificate* selected_cert_; 50 X509Certificate* selected_cert_;
52 int cert_selected_callbacks_; 51 int cert_selected_callbacks_;
53 JNIEnv* env_; 52 JNIEnv* env_;
54 }; 53 };
55 54
55 class TestClientCertificateDelegate
56 : public content::ClientCertificateDelegate {
57 public:
58 explicit TestClientCertificateDelegate(AwContentsClientBridgeTest* test)
59 : test_(test) {}
60
61 // content::ClientCertificateDelegate.
62 void ContinueWithCertificate(net::X509Certificate* cert) override {
63 test_->CertSelected(cert);
64 test_ = nullptr;
65 }
66
67 private:
68 AwContentsClientBridgeTest* test_;
69
70 DISALLOW_COPY_AND_ASSIGN(TestClientCertificateDelegate);
71 };
72
56 } // namespace 73 } // namespace
57 74
58 void AwContentsClientBridgeTest::SetUp() { 75 void AwContentsClientBridgeTest::SetUp() {
59 env_ = AttachCurrentThread(); 76 env_ = AttachCurrentThread();
60 ASSERT_THAT(env_, NotNull()); 77 ASSERT_THAT(env_, NotNull());
61 ASSERT_TRUE(android_webview::RegisterAwContentsClientBridge(env_)); 78 ASSERT_TRUE(android_webview::RegisterAwContentsClientBridge(env_));
62 ASSERT_TRUE(RegisterNativesImpl(env_)); 79 ASSERT_TRUE(RegisterNativesImpl(env_));
63 ASSERT_TRUE(net::android::RegisterJni(env_)); 80 ASSERT_TRUE(net::android::RegisterJni(env_));
64 jbridge_.Reset(env_, 81 jbridge_.Reset(env_,
65 Java_MockAwContentsClientBridge_getAwContentsClientBridge(env_).obj()); 82 Java_MockAwContentsClientBridge_getAwContentsClientBridge(env_).obj());
(...skipping 17 matching lines...) Expand all
83 TestCertType(cert_types[i], expected_names[i]); 100 TestCertType(cert_types[i], expected_names[i]);
84 } 101 }
85 } 102 }
86 103
87 void AwContentsClientBridgeTest::TestCertType(SSLClientCertType type, 104 void AwContentsClientBridgeTest::TestCertType(SSLClientCertType type,
88 const std::string& expected_name) { 105 const std::string& expected_name) {
89 cert_request_info_->cert_key_types.clear(); 106 cert_request_info_->cert_key_types.clear();
90 cert_request_info_->cert_key_types.push_back(type); 107 cert_request_info_->cert_key_types.push_back(type);
91 bridge_->SelectClientCertificate( 108 bridge_->SelectClientCertificate(
92 cert_request_info_.get(), 109 cert_request_info_.get(),
93 base::Bind( 110 make_scoped_ptr(new TestClientCertificateDelegate(this)));
94 &AwContentsClientBridgeTest::CertSelected,
95 base::Unretained(static_cast<AwContentsClientBridgeTest*>(this))));
96 base::RunLoop().RunUntilIdle(); 111 base::RunLoop().RunUntilIdle();
97 EXPECT_EQ(0, cert_selected_callbacks_); 112 EXPECT_EQ(0, cert_selected_callbacks_);
98 ScopedJavaLocalRef<jobjectArray> key_types = 113 ScopedJavaLocalRef<jobjectArray> key_types =
99 Java_MockAwContentsClientBridge_getKeyTypes(env_, jbridge_.obj()); 114 Java_MockAwContentsClientBridge_getKeyTypes(env_, jbridge_.obj());
100 std::vector<std::string> vec; 115 std::vector<std::string> vec;
101 base::android::AppendJavaStringArrayToStringVector(env_, 116 base::android::AppendJavaStringArrayToStringVector(env_,
102 key_types.obj(), 117 key_types.obj(),
103 &vec); 118 &vec);
104 EXPECT_EQ(1u, vec.size()); 119 EXPECT_EQ(1u, vec.size());
105 EXPECT_EQ(expected_name, vec[0]); 120 EXPECT_EQ(expected_name, vec[0]);
106 } 121 }
107 122
108 // Verify that ProvideClientCertificateResponse works properly when the client 123 // Verify that ProvideClientCertificateResponse works properly when the client
109 // responds with a null key. 124 // responds with a null key.
110 TEST_F(AwContentsClientBridgeTest, 125 TEST_F(AwContentsClientBridgeTest,
111 TestProvideClientCertificateResponseCallsCallbackOnNullKey) { 126 TestProvideClientCertificateResponseCallsCallbackOnNullKey) {
112 // Call SelectClientCertificate to create a callback id that mock java object 127 // Call SelectClientCertificate to create a callback id that mock java object
113 // can call on. 128 // can call on.
114 bridge_->SelectClientCertificate( 129 bridge_->SelectClientCertificate(
115 cert_request_info_.get(), 130 cert_request_info_.get(),
116 base::Bind( 131 make_scoped_ptr(new TestClientCertificateDelegate(this)));
117 &AwContentsClientBridgeTest::CertSelected,
118 base::Unretained(static_cast<AwContentsClientBridgeTest*>(this))));
119 bridge_->ProvideClientCertificateResponse(env_, jbridge_.obj(), 132 bridge_->ProvideClientCertificateResponse(env_, jbridge_.obj(),
120 Java_MockAwContentsClientBridge_getRequestId(env_, jbridge_.obj()), 133 Java_MockAwContentsClientBridge_getRequestId(env_, jbridge_.obj()),
121 Java_MockAwContentsClientBridge_createTestCertChain( 134 Java_MockAwContentsClientBridge_createTestCertChain(
122 env_, jbridge_.obj()).obj(), 135 env_, jbridge_.obj()).obj(),
123 NULL); 136 NULL);
124 base::RunLoop().RunUntilIdle(); 137 base::RunLoop().RunUntilIdle();
125 EXPECT_EQ(NULL, selected_cert_); 138 EXPECT_EQ(NULL, selected_cert_);
126 EXPECT_EQ(1, cert_selected_callbacks_); 139 EXPECT_EQ(1, cert_selected_callbacks_);
127 } 140 }
128 141
129 // Verify that ProvideClientCertificateResponse calls the callback with 142 // Verify that ProvideClientCertificateResponse calls the callback with
130 // NULL parameters when private key is not provided. 143 // NULL parameters when private key is not provided.
131 TEST_F(AwContentsClientBridgeTest, 144 TEST_F(AwContentsClientBridgeTest,
132 TestProvideClientCertificateResponseCallsCallbackOnNullChain) { 145 TestProvideClientCertificateResponseCallsCallbackOnNullChain) {
133 // Call SelectClientCertificate to create a callback id that mock java object 146 // Call SelectClientCertificate to create a callback id that mock java object
134 // can call on. 147 // can call on.
135 bridge_->SelectClientCertificate( 148 bridge_->SelectClientCertificate(
136 cert_request_info_.get(), 149 cert_request_info_.get(),
137 base::Bind( 150 make_scoped_ptr(new TestClientCertificateDelegate(this)));
138 &AwContentsClientBridgeTest::CertSelected,
139 base::Unretained(static_cast<AwContentsClientBridgeTest*>(this))));
140 int requestId = 151 int requestId =
141 Java_MockAwContentsClientBridge_getRequestId(env_, jbridge_.obj()); 152 Java_MockAwContentsClientBridge_getRequestId(env_, jbridge_.obj());
142 bridge_->ProvideClientCertificateResponse(env_, jbridge_.obj(), 153 bridge_->ProvideClientCertificateResponse(env_, jbridge_.obj(),
143 requestId, 154 requestId,
144 NULL, 155 NULL,
145 Java_MockAwContentsClientBridge_createTestPrivateKey( 156 Java_MockAwContentsClientBridge_createTestPrivateKey(
146 env_, jbridge_.obj()).obj()); 157 env_, jbridge_.obj()).obj());
147 base::RunLoop().RunUntilIdle(); 158 base::RunLoop().RunUntilIdle();
148 EXPECT_EQ(NULL, selected_cert_); 159 EXPECT_EQ(NULL, selected_cert_);
149 EXPECT_EQ(1, cert_selected_callbacks_); 160 EXPECT_EQ(1, cert_selected_callbacks_);
150 } 161 }
151 162
152 } // android_webview 163 } // android_webview
OLDNEW
« no previous file with comments | « android_webview/native/aw_contents_client_bridge.cc ('k') | chrome/browser/chrome_content_browser_client.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698