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

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: adjust comment Created 5 years, 10 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 ~TestClientCertificateDelegate() {
62 EXPECT_FALSE(test_);
63 }
64
65 // content::ClientCertificateDelegate.
66 void ContinueWithCertificate(net::X509Certificate* cert) override {
67 test_->CertSelected(cert);
68 test_ = nullptr;
69 }
70
71 private:
72 AwContentsClientBridgeTest* test_;
73
74 DISALLOW_COPY_AND_ASSIGN(TestClientCertificateDelegate);
75 };
76
56 } // namespace 77 } // namespace
57 78
58 void AwContentsClientBridgeTest::SetUp() { 79 void AwContentsClientBridgeTest::SetUp() {
59 env_ = AttachCurrentThread(); 80 env_ = AttachCurrentThread();
60 ASSERT_THAT(env_, NotNull()); 81 ASSERT_THAT(env_, NotNull());
61 ASSERT_TRUE(android_webview::RegisterAwContentsClientBridge(env_)); 82 ASSERT_TRUE(android_webview::RegisterAwContentsClientBridge(env_));
62 ASSERT_TRUE(RegisterNativesImpl(env_)); 83 ASSERT_TRUE(RegisterNativesImpl(env_));
63 ASSERT_TRUE(net::android::RegisterJni(env_)); 84 ASSERT_TRUE(net::android::RegisterJni(env_));
64 jbridge_.Reset(env_, 85 jbridge_.Reset(env_,
65 Java_MockAwContentsClientBridge_getAwContentsClientBridge(env_).obj()); 86 Java_MockAwContentsClientBridge_getAwContentsClientBridge(env_).obj());
(...skipping 17 matching lines...) Expand all
83 TestCertType(cert_types[i], expected_names[i]); 104 TestCertType(cert_types[i], expected_names[i]);
84 } 105 }
85 } 106 }
86 107
87 void AwContentsClientBridgeTest::TestCertType(SSLClientCertType type, 108 void AwContentsClientBridgeTest::TestCertType(SSLClientCertType type,
88 const std::string& expected_name) { 109 const std::string& expected_name) {
89 cert_request_info_->cert_key_types.clear(); 110 cert_request_info_->cert_key_types.clear();
90 cert_request_info_->cert_key_types.push_back(type); 111 cert_request_info_->cert_key_types.push_back(type);
91 bridge_->SelectClientCertificate( 112 bridge_->SelectClientCertificate(
92 cert_request_info_.get(), 113 cert_request_info_.get(),
93 base::Bind( 114 make_scoped_ptr(new TestClientCertificateDelegate(this)));
94 &AwContentsClientBridgeTest::CertSelected,
95 base::Unretained(static_cast<AwContentsClientBridgeTest*>(this))));
96 base::RunLoop().RunUntilIdle(); 115 base::RunLoop().RunUntilIdle();
97 EXPECT_EQ(0, cert_selected_callbacks_); 116 EXPECT_EQ(0, cert_selected_callbacks_);
98 ScopedJavaLocalRef<jobjectArray> key_types = 117 ScopedJavaLocalRef<jobjectArray> key_types =
99 Java_MockAwContentsClientBridge_getKeyTypes(env_, jbridge_.obj()); 118 Java_MockAwContentsClientBridge_getKeyTypes(env_, jbridge_.obj());
100 std::vector<std::string> vec; 119 std::vector<std::string> vec;
101 base::android::AppendJavaStringArrayToStringVector(env_, 120 base::android::AppendJavaStringArrayToStringVector(env_,
102 key_types.obj(), 121 key_types.obj(),
103 &vec); 122 &vec);
104 EXPECT_EQ(1u, vec.size()); 123 EXPECT_EQ(1u, vec.size());
105 EXPECT_EQ(expected_name, vec[0]); 124 EXPECT_EQ(expected_name, vec[0]);
106 } 125 }
107 126
108 // Verify that ProvideClientCertificateResponse works properly when the client 127 // Verify that ProvideClientCertificateResponse works properly when the client
109 // responds with a null key. 128 // responds with a null key.
110 TEST_F(AwContentsClientBridgeTest, 129 TEST_F(AwContentsClientBridgeTest,
111 TestProvideClientCertificateResponseCallsCallbackOnNullKey) { 130 TestProvideClientCertificateResponseCallsCallbackOnNullKey) {
112 // Call SelectClientCertificate to create a callback id that mock java object 131 // Call SelectClientCertificate to create a callback id that mock java object
113 // can call on. 132 // can call on.
114 bridge_->SelectClientCertificate( 133 bridge_->SelectClientCertificate(
115 cert_request_info_.get(), 134 cert_request_info_.get(),
116 base::Bind( 135 make_scoped_ptr(new TestClientCertificateDelegate(this)));
117 &AwContentsClientBridgeTest::CertSelected,
118 base::Unretained(static_cast<AwContentsClientBridgeTest*>(this))));
119 bridge_->ProvideClientCertificateResponse(env_, jbridge_.obj(), 136 bridge_->ProvideClientCertificateResponse(env_, jbridge_.obj(),
120 Java_MockAwContentsClientBridge_getRequestId(env_, jbridge_.obj()), 137 Java_MockAwContentsClientBridge_getRequestId(env_, jbridge_.obj()),
121 Java_MockAwContentsClientBridge_createTestCertChain( 138 Java_MockAwContentsClientBridge_createTestCertChain(
122 env_, jbridge_.obj()).obj(), 139 env_, jbridge_.obj()).obj(),
123 NULL); 140 NULL);
124 base::RunLoop().RunUntilIdle(); 141 base::RunLoop().RunUntilIdle();
125 EXPECT_EQ(NULL, selected_cert_); 142 EXPECT_EQ(NULL, selected_cert_);
126 EXPECT_EQ(1, cert_selected_callbacks_); 143 EXPECT_EQ(1, cert_selected_callbacks_);
127 } 144 }
128 145
129 // Verify that ProvideClientCertificateResponse calls the callback with 146 // Verify that ProvideClientCertificateResponse calls the callback with
130 // NULL parameters when private key is not provided. 147 // NULL parameters when private key is not provided.
131 TEST_F(AwContentsClientBridgeTest, 148 TEST_F(AwContentsClientBridgeTest,
132 TestProvideClientCertificateResponseCallsCallbackOnNullChain) { 149 TestProvideClientCertificateResponseCallsCallbackOnNullChain) {
133 // Call SelectClientCertificate to create a callback id that mock java object 150 // Call SelectClientCertificate to create a callback id that mock java object
134 // can call on. 151 // can call on.
135 bridge_->SelectClientCertificate( 152 bridge_->SelectClientCertificate(
136 cert_request_info_.get(), 153 cert_request_info_.get(),
137 base::Bind( 154 make_scoped_ptr(new TestClientCertificateDelegate(this)));
138 &AwContentsClientBridgeTest::CertSelected,
139 base::Unretained(static_cast<AwContentsClientBridgeTest*>(this))));
140 int requestId = 155 int requestId =
141 Java_MockAwContentsClientBridge_getRequestId(env_, jbridge_.obj()); 156 Java_MockAwContentsClientBridge_getRequestId(env_, jbridge_.obj());
142 bridge_->ProvideClientCertificateResponse(env_, jbridge_.obj(), 157 bridge_->ProvideClientCertificateResponse(env_, jbridge_.obj(),
143 requestId, 158 requestId,
144 NULL, 159 NULL,
145 Java_MockAwContentsClientBridge_createTestPrivateKey( 160 Java_MockAwContentsClientBridge_createTestPrivateKey(
146 env_, jbridge_.obj()).obj()); 161 env_, jbridge_.obj()).obj());
147 base::RunLoop().RunUntilIdle(); 162 base::RunLoop().RunUntilIdle();
148 EXPECT_EQ(NULL, selected_cert_); 163 EXPECT_EQ(NULL, selected_cert_);
149 EXPECT_EQ(1, cert_selected_callbacks_); 164 EXPECT_EQ(1, cert_selected_callbacks_);
150 } 165 }
151 166
152 } // android_webview 167 } // android_webview
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698