OLD | NEW |
1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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/command_line.h" | 5 #include "base/command_line.h" |
6 #include "base/macros.h" | 6 #include "base/macros.h" |
7 #include "base/run_loop.h" | 7 #include "base/run_loop.h" |
8 #include "content/browser/storage_partition_impl.h" | 8 #include "content/browser/storage_partition_impl.h" |
9 #include "content/public/browser/browser_context.h" | 9 #include "content/public/browser/browser_context.h" |
10 #include "content/public/browser/payment_app_provider.h" | 10 #include "content/public/browser/payment_app_provider.h" |
(...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
77 EXPECT_TRUE(RunScript("resultQueue.pop()", &script_result)); | 77 EXPECT_TRUE(RunScript("resultQueue.pop()", &script_result)); |
78 return script_result; | 78 return script_result; |
79 } | 79 } |
80 | 80 |
81 void RegisterPaymentApp() { | 81 void RegisterPaymentApp() { |
82 std::string script_result; | 82 std::string script_result; |
83 ASSERT_TRUE(RunScript("registerPaymentApp()", &script_result)); | 83 ASSERT_TRUE(RunScript("registerPaymentApp()", &script_result)); |
84 ASSERT_EQ("registered", script_result); | 84 ASSERT_EQ("registered", script_result); |
85 } | 85 } |
86 | 86 |
87 std::map<std::string, int64_t> GetAllPaymentInstrumentRegistrationIDs() { | 87 std::vector<int64_t> GetAllPaymentAppRegistrationIDs() { |
88 base::RunLoop run_loop; | 88 base::RunLoop run_loop; |
89 PaymentAppProvider::PaymentApps apps; | 89 PaymentAppProvider::PaymentApps apps; |
90 PaymentAppProvider::GetInstance()->GetAllPaymentApps( | 90 PaymentAppProvider::GetInstance()->GetAllPaymentApps( |
91 shell()->web_contents()->GetBrowserContext(), | 91 shell()->web_contents()->GetBrowserContext(), |
92 base::BindOnce(&GetAllPaymentAppsCallback, run_loop.QuitClosure(), | 92 base::BindOnce(&GetAllPaymentAppsCallback, run_loop.QuitClosure(), |
93 &apps)); | 93 &apps)); |
94 run_loop.Run(); | 94 run_loop.Run(); |
95 | 95 |
96 std::map<std::string, int64_t> registrationIds; | 96 std::vector<int64_t> registrationIds; |
97 for (const auto& app_info : apps) { | 97 for (const auto& app_info : apps) { |
98 for (const auto& instrument : app_info.second->instruments) { | 98 registrationIds.push_back(app_info.second->registration_id); |
99 registrationIds.insert(std::pair<std::string, int64_t>( | |
100 instrument->instrument_key, app_info.second->registration_id)); | |
101 } | |
102 } | 99 } |
103 | 100 |
104 return registrationIds; | 101 return registrationIds; |
105 } | 102 } |
106 | 103 |
107 PaymentAppResponsePtr InvokePaymentAppWithTestData( | 104 PaymentAppResponsePtr InvokePaymentAppWithTestData( |
108 int64_t registration_id, | 105 int64_t registration_id, |
109 const std::string& supported_method, | 106 const std::string& supported_method, |
110 const std::string& instrument_key) { | 107 const std::string& instrument_key) { |
111 PaymentRequestEventDataPtr event_data = PaymentRequestEventData::New(); | 108 PaymentRequestEventDataPtr event_data = PaymentRequestEventData::New(); |
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
163 | 160 |
164 private: | 161 private: |
165 std::unique_ptr<net::EmbeddedTestServer> https_server_; | 162 std::unique_ptr<net::EmbeddedTestServer> https_server_; |
166 | 163 |
167 DISALLOW_COPY_AND_ASSIGN(PaymentAppBrowserTest); | 164 DISALLOW_COPY_AND_ASSIGN(PaymentAppBrowserTest); |
168 }; | 165 }; |
169 | 166 |
170 IN_PROC_BROWSER_TEST_F(PaymentAppBrowserTest, PaymentAppInvocation) { | 167 IN_PROC_BROWSER_TEST_F(PaymentAppBrowserTest, PaymentAppInvocation) { |
171 RegisterPaymentApp(); | 168 RegisterPaymentApp(); |
172 | 169 |
173 std::map<std::string, int64_t> registrationIds = | 170 std::vector<int64_t> registrationIds = GetAllPaymentAppRegistrationIDs(); |
174 GetAllPaymentInstrumentRegistrationIDs(); | 171 ASSERT_EQ(1U, registrationIds.size()); |
175 ASSERT_EQ(2U, registrationIds.size()); | |
176 | 172 |
177 PaymentAppResponsePtr response(InvokePaymentAppWithTestData( | 173 PaymentAppResponsePtr response(InvokePaymentAppWithTestData( |
178 registrationIds.at("basic-card-payment-app-id"), "basic-card", | 174 registrationIds[0], "basic-card", "basic-card-payment-app-id")); |
179 "basic-card-payment-app-id")); | |
180 ASSERT_EQ("test", response->method_name); | 175 ASSERT_EQ("test", response->method_name); |
181 | 176 |
182 ClearStoragePartitionData(); | 177 ClearStoragePartitionData(); |
183 | 178 |
184 registrationIds = GetAllPaymentInstrumentRegistrationIDs(); | 179 registrationIds = GetAllPaymentAppRegistrationIDs(); |
185 ASSERT_EQ(0U, registrationIds.size()); | 180 ASSERT_EQ(0U, registrationIds.size()); |
186 | 181 |
187 EXPECT_EQ("https://example.com/", PopConsoleString() /* topLevelOrigin */); | 182 EXPECT_EQ("https://example.com/", PopConsoleString() /* topLevelOrigin */); |
188 EXPECT_EQ("https://example.com/", | 183 EXPECT_EQ("https://example.com/", |
189 PopConsoleString() /* paymentRequestOrigin */); | 184 PopConsoleString() /* paymentRequestOrigin */); |
190 EXPECT_EQ("payment-request-id", PopConsoleString() /* paymentRequestId */); | 185 EXPECT_EQ("payment-request-id", PopConsoleString() /* paymentRequestId */); |
191 EXPECT_EQ("[{\"supportedMethods\":[\"basic-card\"]}]", | 186 EXPECT_EQ("[{\"supportedMethods\":[\"basic-card\"]}]", |
192 PopConsoleString() /* methodData */); | 187 PopConsoleString() /* methodData */); |
193 EXPECT_EQ( | 188 EXPECT_EQ( |
194 "{\"amount\":{\"currency\":\"USD\",\"currencySystem\":\"urn:iso:std:iso:" | 189 "{\"amount\":{\"currency\":\"USD\",\"currencySystem\":\"urn:iso:std:iso:" |
195 "4217\",\"value\":\"\"},\"label\":\"\",\"pending\":false}", | 190 "4217\",\"value\":\"\"},\"label\":\"\",\"pending\":false}", |
196 PopConsoleString() /* total */); | 191 PopConsoleString() /* total */); |
197 EXPECT_EQ( | 192 EXPECT_EQ( |
198 "[{\"additionalDisplayItems\":[],\"supportedMethods\":[\"basic-card\"]," | 193 "[{\"additionalDisplayItems\":[],\"supportedMethods\":[\"basic-card\"]," |
199 "\"total\":{\"amount\":{\"currency\":\"USD\",\"currencySystem\":\"urn:" | 194 "\"total\":{\"amount\":{\"currency\":\"USD\",\"currencySystem\":\"urn:" |
200 "iso:std:iso:4217\",\"value\":\"\"},\"label\":\"\",\"pending\":false}}]", | 195 "iso:std:iso:4217\",\"value\":\"\"},\"label\":\"\",\"pending\":false}}]", |
201 PopConsoleString() /* modifiers */); | 196 PopConsoleString() /* modifiers */); |
202 EXPECT_EQ("basic-card-payment-app-id", | 197 EXPECT_EQ("basic-card-payment-app-id", |
203 PopConsoleString() /* instrumentKey */); | 198 PopConsoleString() /* instrumentKey */); |
204 } | 199 } |
205 | 200 |
206 IN_PROC_BROWSER_TEST_F(PaymentAppBrowserTest, PaymentAppOpenWindowFailed) { | 201 IN_PROC_BROWSER_TEST_F(PaymentAppBrowserTest, PaymentAppOpenWindowFailed) { |
207 RegisterPaymentApp(); | 202 RegisterPaymentApp(); |
208 | 203 |
209 std::map<std::string, int64_t> registrationIds = | 204 std::vector<int64_t> registrationIds = GetAllPaymentAppRegistrationIDs(); |
210 GetAllPaymentInstrumentRegistrationIDs(); | 205 ASSERT_EQ(1U, registrationIds.size()); |
211 ASSERT_EQ(2U, registrationIds.size()); | |
212 | 206 |
213 PaymentAppResponsePtr response(InvokePaymentAppWithTestData( | 207 PaymentAppResponsePtr response(InvokePaymentAppWithTestData( |
214 registrationIds.at("bobpay-payment-app-id"), "https://bobpay.com", | 208 registrationIds[0], "https://bobpay.com", "bobpay-payment-app-id")); |
215 "bobpay-payment-app-id")); | |
216 // InvokePaymentAppCallback returns empty method_name in case of failure, like | 209 // InvokePaymentAppCallback returns empty method_name in case of failure, like |
217 // in PaymentRequestRespondWithObserver::OnResponseRejected. | 210 // in PaymentRequestRespondWithObserver::OnResponseRejected. |
218 ASSERT_EQ("", response->method_name); | 211 ASSERT_EQ("", response->method_name); |
219 | 212 |
220 ClearStoragePartitionData(); | 213 ClearStoragePartitionData(); |
221 | 214 |
222 registrationIds = GetAllPaymentInstrumentRegistrationIDs(); | 215 registrationIds = GetAllPaymentAppRegistrationIDs(); |
223 ASSERT_EQ(0U, registrationIds.size()); | 216 ASSERT_EQ(0U, registrationIds.size()); |
224 | 217 |
225 EXPECT_EQ("https://example.com/", PopConsoleString() /* topLevelOrigin */); | 218 EXPECT_EQ("https://example.com/", PopConsoleString() /* topLevelOrigin */); |
226 EXPECT_EQ("https://example.com/", | 219 EXPECT_EQ("https://example.com/", |
227 PopConsoleString() /* paymentRequestOrigin */); | 220 PopConsoleString() /* paymentRequestOrigin */); |
228 EXPECT_EQ("payment-request-id", PopConsoleString() /* paymentRequestId */); | 221 EXPECT_EQ("payment-request-id", PopConsoleString() /* paymentRequestId */); |
229 EXPECT_EQ("[{\"supportedMethods\":[\"https://bobpay.com\"]}]", | 222 EXPECT_EQ("[{\"supportedMethods\":[\"https://bobpay.com\"]}]", |
230 PopConsoleString() /* methodData */); | 223 PopConsoleString() /* methodData */); |
231 EXPECT_EQ( | 224 EXPECT_EQ( |
232 "{\"amount\":{\"currency\":\"USD\",\"currencySystem\":\"urn:iso:std:iso:" | 225 "{\"amount\":{\"currency\":\"USD\",\"currencySystem\":\"urn:iso:std:iso:" |
233 "4217\",\"value\":\"\"},\"label\":\"\",\"pending\":false}", | 226 "4217\",\"value\":\"\"},\"label\":\"\",\"pending\":false}", |
234 PopConsoleString() /* total */); | 227 PopConsoleString() /* total */); |
235 EXPECT_EQ( | 228 EXPECT_EQ( |
236 "[{\"additionalDisplayItems\":[],\"supportedMethods\":[\"https://" | 229 "[{\"additionalDisplayItems\":[],\"supportedMethods\":[\"https://" |
237 "bobpay.com\"]," | 230 "bobpay.com\"]," |
238 "\"total\":{\"amount\":{\"currency\":\"USD\",\"currencySystem\":\"urn:" | 231 "\"total\":{\"amount\":{\"currency\":\"USD\",\"currencySystem\":\"urn:" |
239 "iso:std:iso:4217\",\"value\":\"\"},\"label\":\"\",\"pending\":false}}]", | 232 "iso:std:iso:4217\",\"value\":\"\"},\"label\":\"\",\"pending\":false}}]", |
240 PopConsoleString() /* modifiers */); | 233 PopConsoleString() /* modifiers */); |
241 EXPECT_EQ("bobpay-payment-app-id", PopConsoleString() /* instrumentKey */); | 234 EXPECT_EQ("bobpay-payment-app-id", PopConsoleString() /* instrumentKey */); |
242 } | 235 } |
243 } // namespace content | 236 } // namespace content |
OLD | NEW |