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

Unified Diff: components/payments/content/payment_request_state_unittest.cc

Issue 2836353002: [Payments] Normalize shipping address change on Desktop (Closed)
Patch Set: Fixed BUILD deps Created 3 years, 8 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 side-by-side diff with in-line comments
Download patch
Index: components/payments/content/payment_request_state_unittest.cc
diff --git a/components/payments/content/payment_request_state_unittest.cc b/components/payments/content/payment_request_state_unittest.cc
index 6b18b1775a1489abcc864655640529fa5d8844e7..d06434c72b3671a2359aaf1e5c52ab3aa656bbba 100644
--- a/components/payments/content/payment_request_state_unittest.cc
+++ b/components/payments/content/payment_request_state_unittest.cc
@@ -13,6 +13,7 @@
#include "components/autofill/core/browser/credit_card.h"
#include "components/autofill/core/browser/test_personal_data_manager.h"
#include "components/payments/content/payment_request_spec.h"
+#include "components/payments/core/test_payment_request_delegate.h"
#include "components/payments/mojom/payment_request.mojom.h"
#include "testing/gtest/include/gtest/gtest.h"
@@ -24,6 +25,7 @@ class PaymentRequestStateTest : public testing::Test,
protected:
PaymentRequestStateTest()
: num_on_selected_information_changed_called_(0),
+ test_payment_request_delegate_(nullptr),
Mathieu 2017/04/27 11:04:01 /*personal_data_manager=*/
sebsg 2017/04/27 14:43:23 Done.
address_(autofill::test::GetFullProfile()),
credit_card_visa_(autofill::test::GetCreditCard()) {
test_personal_data_manager_.AddTestingProfile(&address_);
@@ -43,7 +45,9 @@ class PaymentRequestStateTest : public testing::Test,
payment_response_ = std::move(response);
};
void OnShippingOptionIdSelected(std::string shipping_option_id) override {}
- void OnShippingAddressSelected(mojom::PaymentAddressPtr address) override {}
+ void OnShippingAddressSelected(mojom::PaymentAddressPtr address) override {
+ selected_shipping_address_ = std::move(address);
+ }
void RecreateStateWithOptionsAndDetails(
mojom::PaymentOptionsPtr options,
@@ -54,14 +58,21 @@ class PaymentRequestStateTest : public testing::Test,
std::move(options), std::move(details), std::move(method_data), nullptr,
"en-US");
state_ = base::MakeUnique<PaymentRequestState>(
- spec_.get(), this, "en-US", &test_personal_data_manager_, nullptr);
+ spec_.get(), this, "en-US", &test_personal_data_manager_,
+ &test_payment_request_delegate_);
state_->AddObserver(this);
}
// Convenience method to create a PaymentRequestState with default details
// (one shipping option) and method data (only supports visa).
void RecreateStateWithOptions(mojom::PaymentOptionsPtr options) {
- // Create dummy PaymentDetails with a single shipping option.
+ RecreateStateWithOptionsAndDetails(
+ std::move(options), CreateDefaultDetails(), GetMethodDataForVisa());
+ }
+
+ // Convenience method that returns a dummy PaymentDetails with a single
+ // shipping option.
+ mojom::PaymentDetailsPtr CreateDefaultDetails() {
std::vector<mojom::PaymentShippingOptionPtr> shipping_options;
mojom::PaymentShippingOptionPtr option =
mojom::PaymentShippingOption::New();
@@ -69,9 +80,7 @@ class PaymentRequestStateTest : public testing::Test,
shipping_options.push_back(std::move(option));
mojom::PaymentDetailsPtr details = mojom::PaymentDetails::New();
details->shipping_options = std::move(shipping_options);
-
- RecreateStateWithOptionsAndDetails(std::move(options), std::move(details),
- GetMethodDataForVisa());
+ return details;
}
// Convenience method that returns MethodData that supports Visa.
@@ -84,19 +93,28 @@ class PaymentRequestStateTest : public testing::Test,
}
PaymentRequestState* state() { return state_.get(); }
+ PaymentRequestSpec* spec() { return spec_.get(); }
const mojom::PaymentResponsePtr& response() { return payment_response_; }
+ const mojom::PaymentAddressPtr& selected_shipping_address() {
+ return selected_shipping_address_;
+ }
int num_on_selected_information_changed_called() {
return num_on_selected_information_changed_called_;
}
autofill::AutofillProfile* test_address() { return &address_; }
+ TestPaymentRequestDelegate* test_payment_request_delegate() {
+ return &test_payment_request_delegate_;
+ }
private:
std::unique_ptr<PaymentRequestState> state_;
std::unique_ptr<PaymentRequestSpec> spec_;
int num_on_selected_information_changed_called_;
mojom::PaymentResponsePtr payment_response_;
+ mojom::PaymentAddressPtr selected_shipping_address_;
autofill::TestPersonalDataManager test_personal_data_manager_;
+ TestPaymentRequestDelegate test_payment_request_delegate_;
// Test data.
autofill::AutofillProfile address_;
@@ -206,6 +224,9 @@ TEST_F(PaymentRequestStateTest, ReadyToPay_DefaultSelections) {
state()->SetSelectedShippingProfile(test_address());
EXPECT_EQ(1, num_on_selected_information_changed_called());
+ // Simulate that the merchant has validated the shipping address change.
+ spec()->UpdateWith(CreateDefaultDetails());
+ EXPECT_EQ(2, num_on_selected_information_changed_called());
EXPECT_TRUE(state()->is_ready_to_pay());
}
@@ -247,4 +268,49 @@ TEST_F(PaymentRequestStateTest, ReadyToPay_ContactInfo) {
EXPECT_TRUE(state()->is_ready_to_pay());
}
+TEST_F(PaymentRequestStateTest, SelectedShippingAddressMessage_Normalized) {
+ mojom::PaymentOptionsPtr options = mojom::PaymentOptions::New();
+ options->request_shipping = true;
+ RecreateStateWithOptions(std::move(options));
+
+ // Make the normalization not be instantaneous.
+ test_payment_request_delegate()
+ ->GetTestAddressNormalizer()
+ ->DelayNormalization();
+
+ EXPECT_EQ(0, num_on_selected_information_changed_called());
+
+ // Select an address, nothing should happen until the normalization is
+ // completed and the merchant has validated the address.
+ state()->SetSelectedShippingProfile(test_address());
+ EXPECT_EQ(1, num_on_selected_information_changed_called());
+ EXPECT_FALSE(state()->is_ready_to_pay());
+
+ // Complete the normalization.
+ test_payment_request_delegate()
+ ->GetTestAddressNormalizer()
+ ->CompleteAddressNormalization();
+ EXPECT_EQ(1, num_on_selected_information_changed_called());
+ EXPECT_FALSE(state()->is_ready_to_pay());
+
+ // Simulate that the merchant has validated the shipping address change.
+ spec()->UpdateWith(CreateDefaultDetails());
+ EXPECT_EQ(2, num_on_selected_information_changed_called());
+ EXPECT_TRUE(state()->is_ready_to_pay());
+
+ // Check that all the expected values were set for the shipping address.
+ EXPECT_EQ("US", selected_shipping_address()->country);
+ EXPECT_EQ("666 Erebus St.", selected_shipping_address()->address_line[0]);
+ EXPECT_EQ("Apt 8", selected_shipping_address()->address_line[1]);
+ EXPECT_EQ("CA", selected_shipping_address()->region);
+ EXPECT_EQ("Elysium", selected_shipping_address()->city);
+ EXPECT_EQ("", selected_shipping_address()->dependent_locality);
+ EXPECT_EQ("91111", selected_shipping_address()->postal_code);
+ EXPECT_EQ("", selected_shipping_address()->sorting_code);
+ EXPECT_EQ("", selected_shipping_address()->language_code);
+ EXPECT_EQ("Underworld", selected_shipping_address()->organization);
+ EXPECT_EQ("John H. Doe", selected_shipping_address()->recipient);
+ EXPECT_EQ("16502111111", selected_shipping_address()->phone);
+}
+
} // namespace payments
« no previous file with comments | « components/payments/content/payment_request_state.cc ('k') | components/payments/content/payment_response_helper.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698