Chromium Code Reviews| 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/command_line.h" | 6 #include "base/command_line.h" |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/memory/ref_counted.h" | 8 #include "base/memory/ref_counted.h" |
| 9 #include "base/memory/weak_ptr.h" | 9 #include "base/memory/weak_ptr.h" |
| 10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
| (...skipping 538 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 549 EXPECT_EQ(AutofillMetrics::DIALOG_CANCELED, | 549 EXPECT_EQ(AutofillMetrics::DIALOG_CANCELED, |
| 550 metric_logger().dialog_dismissal_action()); | 550 metric_logger().dialog_dismissal_action()); |
| 551 } | 551 } |
| 552 | 552 |
| 553 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, FillInputFromAutofill) { | 553 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, FillInputFromAutofill) { |
| 554 AutofillProfile full_profile(test::GetFullProfile()); | 554 AutofillProfile full_profile(test::GetFullProfile()); |
| 555 controller()->GetTestingManager()->AddTestingProfile(&full_profile); | 555 controller()->GetTestingManager()->AddTestingProfile(&full_profile); |
| 556 | 556 |
| 557 const DetailInputs& inputs = | 557 const DetailInputs& inputs = |
| 558 controller()->RequestedFieldsForSection(SECTION_SHIPPING); | 558 controller()->RequestedFieldsForSection(SECTION_SHIPPING); |
| 559 const DetailInput& triggering_input = inputs[0]; | 559 const ServerFieldType triggering_type = inputs[0].type; |
| 560 base::string16 value = full_profile.GetRawInfo(triggering_input.type); | 560 base::string16 value = full_profile.GetRawInfo(triggering_type); |
| 561 TestableAutofillDialogView* view = controller()->GetTestableView(); | 561 TestableAutofillDialogView* view = controller()->GetTestableView(); |
| 562 view->SetTextContentsOfInput(triggering_input, | 562 view->SetTextContentsOfInput(triggering_type, |
| 563 value.substr(0, value.size() / 2)); | 563 value.substr(0, value.size() / 2)); |
| 564 view->ActivateInput(triggering_input); | 564 view->ActivateInput(triggering_type); |
| 565 | 565 |
| 566 ASSERT_EQ(triggering_input.type, controller()->popup_input_type()); | 566 ASSERT_EQ(triggering_type, controller()->popup_input_type()); |
| 567 controller()->DidAcceptSuggestion(base::string16(), 0); | 567 controller()->DidAcceptSuggestion(base::string16(), 0); |
| 568 | 568 |
| 569 // All inputs should be filled. | 569 // All inputs should be filled. |
| 570 AutofillProfileWrapper wrapper(&full_profile); | 570 AutofillProfileWrapper wrapper(&full_profile); |
| 571 for (size_t i = 0; i < inputs.size(); ++i) { | 571 for (size_t i = 0; i < inputs.size(); ++i) { |
| 572 EXPECT_EQ(wrapper.GetInfo(AutofillType(inputs[i].type)), | 572 EXPECT_EQ(wrapper.GetInfo(AutofillType(inputs[i].type)), |
| 573 view->GetTextContentsOfInput(inputs[i])); | 573 view->GetTextContentsOfInput(inputs[i].type)); |
| 574 } | 574 } |
| 575 | 575 |
| 576 // Now simulate some user edits and try again. | 576 // Now simulate some user edits and try again. |
| 577 std::vector<base::string16> expectations; | 577 std::vector<base::string16> expectations; |
| 578 for (size_t i = 0; i < inputs.size(); ++i) { | 578 for (size_t i = 0; i < inputs.size(); ++i) { |
| 579 base::string16 users_input = i % 2 == 0 ? base::string16() | 579 base::string16 users_input = i % 2 == 0 ? base::string16() |
| 580 : ASCIIToUTF16("dummy"); | 580 : ASCIIToUTF16("dummy"); |
| 581 view->SetTextContentsOfInput(inputs[i], users_input); | 581 view->SetTextContentsOfInput(inputs[i].type, users_input); |
| 582 // Empty inputs should be filled, others should be left alone. | 582 // Empty inputs should be filled, others should be left alone. |
| 583 base::string16 expectation = | 583 base::string16 expectation = |
| 584 &inputs[i] == &triggering_input || users_input.empty() ? | 584 inputs[i].type == triggering_type || users_input.empty() ? |
|
Dan Beam
2014/01/09 04:31:34
^ stuff like this was the general issue
| |
| 585 wrapper.GetInfo(AutofillType(inputs[i].type)) : | 585 wrapper.GetInfo(AutofillType(inputs[i].type)) : |
| 586 users_input; | 586 users_input; |
| 587 expectations.push_back(expectation); | 587 expectations.push_back(expectation); |
| 588 } | 588 } |
| 589 | 589 |
| 590 view->SetTextContentsOfInput(triggering_input, | 590 view->SetTextContentsOfInput(triggering_type, |
| 591 value.substr(0, value.size() / 2)); | 591 value.substr(0, value.size() / 2)); |
| 592 view->ActivateInput(triggering_input); | 592 view->ActivateInput(triggering_type); |
| 593 ASSERT_EQ(triggering_input.type, controller()->popup_input_type()); | 593 ASSERT_EQ(triggering_type, controller()->popup_input_type()); |
| 594 controller()->DidAcceptSuggestion(base::string16(), 0); | 594 controller()->DidAcceptSuggestion(base::string16(), 0); |
| 595 | 595 |
| 596 for (size_t i = 0; i < inputs.size(); ++i) { | 596 for (size_t i = 0; i < inputs.size(); ++i) { |
| 597 EXPECT_EQ(expectations[i], view->GetTextContentsOfInput(inputs[i])); | 597 EXPECT_EQ(expectations[i], view->GetTextContentsOfInput(inputs[i].type)); |
| 598 } | 598 } |
| 599 } | 599 } |
| 600 | 600 |
| 601 // For now, no matter what, the country must always be US. See | 601 // For now, no matter what, the country must always be US. See |
| 602 // http://crbug.com/247518 | 602 // http://crbug.com/247518 |
| 603 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, | 603 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, |
| 604 FillInputFromForeignProfile) { | 604 FillInputFromForeignProfile) { |
| 605 AutofillProfile full_profile(test::GetFullProfile()); | 605 AutofillProfile full_profile(test::GetFullProfile()); |
| 606 full_profile.SetInfo(AutofillType(ADDRESS_HOME_COUNTRY), | 606 full_profile.SetInfo(AutofillType(ADDRESS_HOME_COUNTRY), |
| 607 ASCIIToUTF16("France"), "en-US"); | 607 ASCIIToUTF16("France"), "en-US"); |
| 608 controller()->GetTestingManager()->AddTestingProfile(&full_profile); | 608 controller()->GetTestingManager()->AddTestingProfile(&full_profile); |
| 609 | 609 |
| 610 const DetailInputs& inputs = | 610 const DetailInputs& inputs = |
| 611 controller()->RequestedFieldsForSection(SECTION_SHIPPING); | 611 controller()->RequestedFieldsForSection(SECTION_SHIPPING); |
| 612 const DetailInput& triggering_input = inputs[0]; | 612 const ServerFieldType triggering_type = inputs[0].type; |
| 613 base::string16 value = full_profile.GetRawInfo(triggering_input.type); | 613 base::string16 value = full_profile.GetRawInfo(triggering_type); |
| 614 TestableAutofillDialogView* view = controller()->GetTestableView(); | 614 TestableAutofillDialogView* view = controller()->GetTestableView(); |
| 615 view->SetTextContentsOfInput(triggering_input, | 615 view->SetTextContentsOfInput(triggering_type, |
| 616 value.substr(0, value.size() / 2)); | 616 value.substr(0, value.size() / 2)); |
| 617 view->ActivateInput(triggering_input); | 617 view->ActivateInput(triggering_type); |
| 618 | 618 |
| 619 ASSERT_EQ(triggering_input.type, controller()->popup_input_type()); | 619 ASSERT_EQ(triggering_type, controller()->popup_input_type()); |
| 620 controller()->DidAcceptSuggestion(base::string16(), 0); | 620 controller()->DidAcceptSuggestion(base::string16(), 0); |
| 621 | 621 |
| 622 // All inputs should be filled. | 622 // All inputs should be filled. |
| 623 AutofillProfileWrapper wrapper(&full_profile); | 623 AutofillProfileWrapper wrapper(&full_profile); |
| 624 for (size_t i = 0; i < inputs.size(); ++i) { | 624 for (size_t i = 0; i < inputs.size(); ++i) { |
| 625 const ServerFieldType type = inputs[i].type; | |
| 625 base::string16 expectation = | 626 base::string16 expectation = |
| 626 AutofillType(inputs[i].type).GetStorableType() == ADDRESS_HOME_COUNTRY ? | 627 AutofillType(type).GetStorableType() == ADDRESS_HOME_COUNTRY ? |
| 627 ASCIIToUTF16("United States") : | 628 ASCIIToUTF16("United States") : wrapper.GetInfo(AutofillType(type)); |
| 628 wrapper.GetInfo(AutofillType(inputs[i].type)); | 629 EXPECT_EQ(expectation, view->GetTextContentsOfInput(type)); |
| 629 EXPECT_EQ(expectation, view->GetTextContentsOfInput(inputs[i])); | |
| 630 } | 630 } |
| 631 | 631 |
| 632 // Now simulate some user edits and try again. | 632 // Now simulate some user edits and try again. |
| 633 std::vector<base::string16> expectations; | 633 std::vector<base::string16> expectations; |
| 634 for (size_t i = 0; i < inputs.size(); ++i) { | 634 for (size_t i = 0; i < inputs.size(); ++i) { |
| 635 base::string16 users_input = i % 2 == 0 ? base::string16() | 635 base::string16 users_input = i % 2 == 0 ? base::string16() |
| 636 : ASCIIToUTF16("dummy"); | 636 : ASCIIToUTF16("dummy"); |
| 637 view->SetTextContentsOfInput(inputs[i], users_input); | 637 view->SetTextContentsOfInput(inputs[i].type, users_input); |
| 638 // Empty inputs should be filled, others should be left alone. | 638 // Empty inputs should be filled, others should be left alone. |
| 639 base::string16 expectation = | 639 base::string16 expectation = |
| 640 &inputs[i] == &triggering_input || users_input.empty() ? | 640 inputs[i].type == triggering_type || users_input.empty() ? |
| 641 wrapper.GetInfo(AutofillType(inputs[i].type)) : | 641 wrapper.GetInfo(AutofillType(inputs[i].type)) : |
| 642 users_input; | 642 users_input; |
| 643 if (AutofillType(inputs[i].type).GetStorableType() == ADDRESS_HOME_COUNTRY) | 643 if (AutofillType(inputs[i].type).GetStorableType() == ADDRESS_HOME_COUNTRY) |
| 644 expectation = ASCIIToUTF16("United States"); | 644 expectation = ASCIIToUTF16("United States"); |
| 645 | 645 |
| 646 expectations.push_back(expectation); | 646 expectations.push_back(expectation); |
| 647 } | 647 } |
| 648 | 648 |
| 649 view->SetTextContentsOfInput(triggering_input, | 649 view->SetTextContentsOfInput(triggering_type, |
| 650 value.substr(0, value.size() / 2)); | 650 value.substr(0, value.size() / 2)); |
| 651 view->ActivateInput(triggering_input); | 651 view->ActivateInput(triggering_type); |
| 652 ASSERT_EQ(triggering_input.type, controller()->popup_input_type()); | 652 ASSERT_EQ(triggering_type, controller()->popup_input_type()); |
| 653 controller()->DidAcceptSuggestion(base::string16(), 0); | 653 controller()->DidAcceptSuggestion(base::string16(), 0); |
| 654 | 654 |
| 655 for (size_t i = 0; i < inputs.size(); ++i) { | 655 for (size_t i = 0; i < inputs.size(); ++i) { |
| 656 EXPECT_EQ(expectations[i], view->GetTextContentsOfInput(inputs[i])); | 656 EXPECT_EQ(expectations[i], view->GetTextContentsOfInput(inputs[i].type)); |
| 657 } | 657 } |
| 658 } | 658 } |
| 659 | 659 |
| 660 // This test makes sure that picking a profile variant in the Autofill | 660 // This test makes sure that picking a profile variant in the Autofill |
| 661 // popup works as expected. | 661 // popup works as expected. |
| 662 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, | 662 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, |
| 663 FillInputFromAutofillVariant) { | 663 FillInputFromAutofillVariant) { |
| 664 AutofillProfile full_profile(test::GetFullProfile()); | 664 AutofillProfile full_profile(test::GetFullProfile()); |
| 665 | 665 |
| 666 // Set up some variant data. | 666 // Set up some variant data. |
| 667 std::vector<base::string16> names; | 667 std::vector<base::string16> names; |
| 668 names.push_back(ASCIIToUTF16("John Doe")); | 668 names.push_back(ASCIIToUTF16("John Doe")); |
| 669 names.push_back(ASCIIToUTF16("Jane Doe")); | 669 names.push_back(ASCIIToUTF16("Jane Doe")); |
| 670 full_profile.SetRawMultiInfo(NAME_FULL, names); | 670 full_profile.SetRawMultiInfo(NAME_FULL, names); |
| 671 std::vector<base::string16> emails; | 671 std::vector<base::string16> emails; |
| 672 emails.push_back(ASCIIToUTF16("user@example.com")); | 672 emails.push_back(ASCIIToUTF16("user@example.com")); |
| 673 emails.push_back(ASCIIToUTF16("admin@example.com")); | 673 emails.push_back(ASCIIToUTF16("admin@example.com")); |
| 674 full_profile.SetRawMultiInfo(EMAIL_ADDRESS, emails); | 674 full_profile.SetRawMultiInfo(EMAIL_ADDRESS, emails); |
| 675 controller()->GetTestingManager()->AddTestingProfile(&full_profile); | 675 controller()->GetTestingManager()->AddTestingProfile(&full_profile); |
| 676 | 676 |
| 677 const DetailInputs& inputs = | 677 const DetailInputs& inputs = |
| 678 controller()->RequestedFieldsForSection(SECTION_BILLING); | 678 controller()->RequestedFieldsForSection(SECTION_BILLING); |
| 679 const DetailInput& triggering_input = inputs[0]; | 679 const ServerFieldType triggering_type = inputs[0].type; |
| 680 EXPECT_EQ(NAME_BILLING_FULL, triggering_input.type); | 680 EXPECT_EQ(NAME_BILLING_FULL, triggering_type); |
| 681 TestableAutofillDialogView* view = controller()->GetTestableView(); | 681 TestableAutofillDialogView* view = controller()->GetTestableView(); |
| 682 view->ActivateInput(triggering_input); | 682 view->ActivateInput(triggering_type); |
| 683 | 683 |
| 684 ASSERT_EQ(triggering_input.type, controller()->popup_input_type()); | 684 ASSERT_EQ(triggering_type, controller()->popup_input_type()); |
| 685 | 685 |
| 686 // Choose the variant suggestion. | 686 // Choose the variant suggestion. |
| 687 controller()->DidAcceptSuggestion(base::string16(), 1); | 687 controller()->DidAcceptSuggestion(base::string16(), 1); |
| 688 | 688 |
| 689 // All inputs should be filled. | 689 // All inputs should be filled. |
| 690 AutofillProfileWrapper wrapper( | 690 AutofillProfileWrapper wrapper( |
| 691 &full_profile, AutofillType(NAME_BILLING_FULL), 1); | 691 &full_profile, AutofillType(NAME_BILLING_FULL), 1); |
| 692 for (size_t i = 0; i < inputs.size(); ++i) { | 692 for (size_t i = 0; i < inputs.size(); ++i) { |
| 693 EXPECT_EQ(wrapper.GetInfo(AutofillType(inputs[i].type)), | 693 EXPECT_EQ(wrapper.GetInfo(AutofillType(inputs[i].type)), |
| 694 view->GetTextContentsOfInput(inputs[i])); | 694 view->GetTextContentsOfInput(inputs[i].type)); |
| 695 } | 695 } |
| 696 | 696 |
| 697 // Make sure the wrapper applies the variant index to the right group. | 697 // Make sure the wrapper applies the variant index to the right group. |
| 698 EXPECT_EQ(names[1], wrapper.GetInfo(AutofillType(NAME_BILLING_FULL))); | 698 EXPECT_EQ(names[1], wrapper.GetInfo(AutofillType(NAME_BILLING_FULL))); |
| 699 // Make sure the wrapper doesn't apply the variant index to the wrong group. | 699 // Make sure the wrapper doesn't apply the variant index to the wrong group. |
| 700 EXPECT_EQ(emails[0], wrapper.GetInfo(AutofillType(EMAIL_ADDRESS))); | 700 EXPECT_EQ(emails[0], wrapper.GetInfo(AutofillType(EMAIL_ADDRESS))); |
| 701 } | 701 } |
| 702 | 702 |
| 703 // Tests that changing the value of a CC expiration date combobox works as | 703 // Tests that changing the value of a CC expiration date combobox works as |
| 704 // expected when Autofill is used to fill text inputs. | 704 // expected when Autofill is used to fill text inputs. |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 715 test::SetCreditCardInfo(&card1, "JJ Smith", "4111111111111111", "12", "2018"); | 715 test::SetCreditCardInfo(&card1, "JJ Smith", "4111111111111111", "12", "2018"); |
| 716 controller()->GetTestingManager()->AddTestingCreditCard(&card1); | 716 controller()->GetTestingManager()->AddTestingCreditCard(&card1); |
| 717 CreditCard card2; | 717 CreditCard card2; |
| 718 test::SetCreditCardInfo(&card2, "B Bird", "3111111111111111", "11", "2017"); | 718 test::SetCreditCardInfo(&card2, "B Bird", "3111111111111111", "11", "2017"); |
| 719 controller()->GetTestingManager()->AddTestingCreditCard(&card2); | 719 controller()->GetTestingManager()->AddTestingCreditCard(&card2); |
| 720 AutofillProfile full_profile(test::GetFullProfile()); | 720 AutofillProfile full_profile(test::GetFullProfile()); |
| 721 controller()->GetTestingManager()->AddTestingProfile(&full_profile); | 721 controller()->GetTestingManager()->AddTestingProfile(&full_profile); |
| 722 | 722 |
| 723 const DetailInputs& inputs = | 723 const DetailInputs& inputs = |
| 724 controller()->RequestedFieldsForSection(SECTION_CC); | 724 controller()->RequestedFieldsForSection(SECTION_CC); |
| 725 const DetailInput& triggering_input = inputs[0]; | 725 const ServerFieldType triggering_type = inputs[0].type; |
| 726 base::string16 value = card1.GetRawInfo(triggering_input.type); | 726 base::string16 value = card1.GetRawInfo(triggering_type); |
| 727 TestableAutofillDialogView* view = controller()->GetTestableView(); | 727 TestableAutofillDialogView* view = controller()->GetTestableView(); |
| 728 view->SetTextContentsOfInput(triggering_input, | 728 view->SetTextContentsOfInput(triggering_type, |
| 729 value.substr(0, value.size() / 2)); | 729 value.substr(0, value.size() / 2)); |
| 730 view->ActivateInput(triggering_input); | 730 view->ActivateInput(triggering_type); |
| 731 | 731 |
| 732 ASSERT_EQ(triggering_input.type, controller()->popup_input_type()); | 732 ASSERT_EQ(triggering_type, controller()->popup_input_type()); |
| 733 controller()->DidAcceptSuggestion(base::string16(), 0); | 733 controller()->DidAcceptSuggestion(base::string16(), 0); |
| 734 | 734 |
| 735 // All inputs should be filled. | 735 // All inputs should be filled. |
| 736 AutofillCreditCardWrapper wrapper1(&card1); | 736 AutofillCreditCardWrapper wrapper1(&card1); |
| 737 for (size_t i = 0; i < inputs.size(); ++i) { | 737 for (size_t i = 0; i < inputs.size(); ++i) { |
| 738 EXPECT_EQ(wrapper1.GetInfo(AutofillType(inputs[i].type)), | 738 EXPECT_EQ(wrapper1.GetInfo(AutofillType(inputs[i].type)), |
| 739 view->GetTextContentsOfInput(inputs[i])); | 739 view->GetTextContentsOfInput(inputs[i].type)); |
| 740 } | 740 } |
| 741 | 741 |
| 742 // Try again with different data. Only expiration date and the triggering | 742 // Try again with different data. Only expiration date and the triggering |
| 743 // input should be overwritten. | 743 // input should be overwritten. |
| 744 value = card2.GetRawInfo(triggering_input.type); | 744 value = card2.GetRawInfo(triggering_type); |
| 745 view->SetTextContentsOfInput(triggering_input, | 745 view->SetTextContentsOfInput(triggering_type, |
| 746 value.substr(0, value.size() / 2)); | 746 value.substr(0, value.size() / 2)); |
| 747 view->ActivateInput(triggering_input); | 747 view->ActivateInput(triggering_type); |
| 748 ASSERT_EQ(triggering_input.type, controller()->popup_input_type()); | 748 ASSERT_EQ(triggering_type, controller()->popup_input_type()); |
| 749 controller()->DidAcceptSuggestion(base::string16(), 0); | 749 controller()->DidAcceptSuggestion(base::string16(), 0); |
| 750 | 750 |
| 751 AutofillCreditCardWrapper wrapper2(&card2); | 751 AutofillCreditCardWrapper wrapper2(&card2); |
| 752 for (size_t i = 0; i < inputs.size(); ++i) { | 752 for (size_t i = 0; i < inputs.size(); ++i) { |
| 753 const DetailInput& input = inputs[i]; | 753 const ServerFieldType type = inputs[i].type; |
| 754 if (&input == &triggering_input || | 754 if (type == triggering_type || |
| 755 input.type == CREDIT_CARD_EXP_MONTH || | 755 type == CREDIT_CARD_EXP_MONTH || |
| 756 input.type == CREDIT_CARD_EXP_4_DIGIT_YEAR) { | 756 type == CREDIT_CARD_EXP_4_DIGIT_YEAR) { |
| 757 EXPECT_EQ(wrapper2.GetInfo(AutofillType(input.type)), | 757 EXPECT_EQ(wrapper2.GetInfo(AutofillType(type)), |
| 758 view->GetTextContentsOfInput(input)); | 758 view->GetTextContentsOfInput(type)); |
| 759 } else if (input.type == CREDIT_CARD_VERIFICATION_CODE) { | 759 } else if (type == CREDIT_CARD_VERIFICATION_CODE) { |
| 760 EXPECT_TRUE(view->GetTextContentsOfInput(input).empty()); | 760 EXPECT_TRUE(view->GetTextContentsOfInput(type).empty()); |
| 761 } else { | 761 } else { |
| 762 EXPECT_EQ(wrapper1.GetInfo(AutofillType(input.type)), | 762 EXPECT_EQ(wrapper1.GetInfo(AutofillType(type)), |
| 763 view->GetTextContentsOfInput(input)); | 763 view->GetTextContentsOfInput(type)); |
| 764 } | 764 } |
| 765 } | 765 } |
| 766 | 766 |
| 767 // Now fill from a profile. It should not overwrite any CC info. | 767 // Now fill from a profile. It should not overwrite any CC info. |
| 768 const DetailInputs& billing_inputs = | 768 const DetailInputs& billing_inputs = |
| 769 controller()->RequestedFieldsForSection(SECTION_BILLING); | 769 controller()->RequestedFieldsForSection(SECTION_BILLING); |
| 770 const DetailInput& billing_triggering_input = billing_inputs[0]; | 770 const ServerFieldType billing_triggering_type = billing_inputs[0].type; |
| 771 value = full_profile.GetRawInfo(triggering_input.type); | 771 value = full_profile.GetRawInfo(triggering_type); |
| 772 view->SetTextContentsOfInput(billing_triggering_input, | 772 view->SetTextContentsOfInput(billing_triggering_type, |
| 773 value.substr(0, value.size() / 2)); | 773 value.substr(0, value.size() / 2)); |
| 774 view->ActivateInput(billing_triggering_input); | 774 view->ActivateInput(billing_triggering_type); |
| 775 | 775 |
| 776 ASSERT_EQ(billing_triggering_input.type, controller()->popup_input_type()); | 776 ASSERT_EQ(billing_triggering_type, controller()->popup_input_type()); |
| 777 controller()->DidAcceptSuggestion(base::string16(), 0); | 777 controller()->DidAcceptSuggestion(base::string16(), 0); |
| 778 | 778 |
| 779 for (size_t i = 0; i < inputs.size(); ++i) { | 779 for (size_t i = 0; i < inputs.size(); ++i) { |
| 780 const DetailInput& input = inputs[i]; | 780 const ServerFieldType type = inputs[i].type; |
| 781 if (&input == &triggering_input || | 781 if (type == triggering_type || |
| 782 input.type == CREDIT_CARD_EXP_MONTH || | 782 type == CREDIT_CARD_EXP_MONTH || |
| 783 input.type == CREDIT_CARD_EXP_4_DIGIT_YEAR) { | 783 type == CREDIT_CARD_EXP_4_DIGIT_YEAR) { |
| 784 EXPECT_EQ(wrapper2.GetInfo(AutofillType(input.type)), | 784 EXPECT_EQ(wrapper2.GetInfo(AutofillType(type)), |
| 785 view->GetTextContentsOfInput(input)); | 785 view->GetTextContentsOfInput(type)); |
| 786 } else if (input.type == CREDIT_CARD_VERIFICATION_CODE) { | 786 } else if (type == CREDIT_CARD_VERIFICATION_CODE) { |
| 787 EXPECT_TRUE(view->GetTextContentsOfInput(input).empty()); | 787 EXPECT_TRUE(view->GetTextContentsOfInput(type).empty()); |
| 788 } else { | 788 } else { |
| 789 EXPECT_EQ(wrapper1.GetInfo(AutofillType(input.type)), | 789 EXPECT_EQ(wrapper1.GetInfo(AutofillType(type)), |
| 790 view->GetTextContentsOfInput(input)); | 790 view->GetTextContentsOfInput(type)); |
| 791 } | 791 } |
| 792 } | 792 } |
| 793 } | 793 } |
| 794 | 794 |
| 795 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, ShouldShowErrorBubble) { | 795 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, ShouldShowErrorBubble) { |
| 796 EXPECT_TRUE(controller()->ShouldShowErrorBubble()); | 796 EXPECT_TRUE(controller()->ShouldShowErrorBubble()); |
| 797 | 797 |
| 798 CreditCard card(test::GetCreditCard()); | 798 CreditCard card(test::GetCreditCard()); |
| 799 ASSERT_FALSE(card.IsVerified()); | 799 ASSERT_FALSE(card.IsVerified()); |
| 800 controller()->GetTestingManager()->AddTestingCreditCard(&card); | 800 controller()->GetTestingManager()->AddTestingCreditCard(&card); |
| 801 | 801 |
| 802 const DetailInputs& cc_inputs = | |
| 803 controller()->RequestedFieldsForSection(SECTION_CC); | |
| 804 const DetailInput& cc_number_input = cc_inputs[0]; | |
| 805 ASSERT_EQ(CREDIT_CARD_NUMBER, cc_number_input.type); | |
| 806 | |
| 807 TestableAutofillDialogView* view = controller()->GetTestableView(); | 802 TestableAutofillDialogView* view = controller()->GetTestableView(); |
| 808 view->SetTextContentsOfInput( | 803 view->SetTextContentsOfInput( |
| 809 cc_number_input, | 804 CREDIT_CARD_NUMBER, |
| 810 card.GetRawInfo(CREDIT_CARD_NUMBER).substr(0, 1)); | 805 card.GetRawInfo(CREDIT_CARD_NUMBER).substr(0, 1)); |
| 811 | 806 |
| 812 view->ActivateInput(cc_number_input); | 807 view->ActivateInput(CREDIT_CARD_NUMBER); |
| 813 EXPECT_FALSE(controller()->ShouldShowErrorBubble()); | 808 EXPECT_FALSE(controller()->ShouldShowErrorBubble()); |
| 814 | 809 |
| 815 controller()->FocusMoved(); | 810 controller()->FocusMoved(); |
| 816 EXPECT_TRUE(controller()->ShouldShowErrorBubble()); | 811 EXPECT_TRUE(controller()->ShouldShowErrorBubble()); |
| 817 } | 812 } |
| 818 | 813 |
| 819 // Ensure that expired cards trigger invalid suggestions. | 814 // Ensure that expired cards trigger invalid suggestions. |
| 820 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, ExpiredCard) { | 815 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, ExpiredCard) { |
| 821 CreditCard verified_card(test::GetCreditCard()); | 816 CreditCard verified_card(test::GetCreditCard()); |
| 822 verified_card.set_origin("Chrome settings"); | 817 verified_card.set_origin("Chrome settings"); |
| (...skipping 125 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 948 // Flaky on Win7, WinXP, and Win Aura. http://crbug.com/270314. | 943 // Flaky on Win7, WinXP, and Win Aura. http://crbug.com/270314. |
| 949 #if defined(OS_WIN) | 944 #if defined(OS_WIN) |
| 950 #define MAYBE_PreservedSections DISABLED_PreservedSections | 945 #define MAYBE_PreservedSections DISABLED_PreservedSections |
| 951 #else | 946 #else |
| 952 #define MAYBE_PreservedSections PreservedSections | 947 #define MAYBE_PreservedSections PreservedSections |
| 953 #endif | 948 #endif |
| 954 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, MAYBE_PreservedSections) { | 949 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, MAYBE_PreservedSections) { |
| 955 controller()->set_use_validation(true); | 950 controller()->set_use_validation(true); |
| 956 | 951 |
| 957 TestableAutofillDialogView* view = controller()->GetTestableView(); | 952 TestableAutofillDialogView* view = controller()->GetTestableView(); |
| 958 | 953 view->SetTextContentsOfInput(CREDIT_CARD_NUMBER, |
| 959 { | 954 ASCIIToUTF16("4111111111111111")); |
| 960 // Create some valid inputted billing data. | |
| 961 const DetailInput& cc_number = | |
| 962 controller()->RequestedFieldsForSection(SECTION_CC)[0]; | |
| 963 EXPECT_EQ(cc_number.type, CREDIT_CARD_NUMBER); | |
| 964 view->SetTextContentsOfInput(cc_number, ASCIIToUTF16("4111111111111111")); | |
| 965 } | |
| 966 | 955 |
| 967 // Create some invalid, manually inputted shipping data. | 956 // Create some invalid, manually inputted shipping data. |
| 968 const DetailInput& shipping_zip = | 957 view->SetTextContentsOfInput(ADDRESS_HOME_ZIP, ASCIIToUTF16("shipping zip")); |
| 969 controller()->RequestedFieldsForSection(SECTION_SHIPPING)[5]; | |
| 970 ASSERT_EQ(ADDRESS_HOME_ZIP, shipping_zip.type); | |
| 971 view->SetTextContentsOfInput(shipping_zip, ASCIIToUTF16("shipping zip")); | |
| 972 | 958 |
| 973 // Switch to Wallet by simulating a successful server response. | 959 // Switch to Wallet by simulating a successful server response. |
| 974 controller()->OnDidFetchWalletCookieValue(std::string()); | 960 controller()->OnDidFetchWalletCookieValue(std::string()); |
| 975 controller()->OnDidGetWalletItems( | 961 controller()->OnDidGetWalletItems( |
| 976 wallet::GetTestWalletItems(wallet::AMEX_DISALLOWED)); | 962 wallet::GetTestWalletItems(wallet::AMEX_DISALLOWED)); |
| 977 ASSERT_TRUE(controller()->IsPayingWithWallet()); | 963 ASSERT_TRUE(controller()->IsPayingWithWallet()); |
| 978 | 964 |
| 979 { | 965 // The valid data should be preserved. |
| 980 // The valid data should be preserved. | 966 EXPECT_EQ(ASCIIToUTF16("4111111111111111"), |
| 981 const DetailInput& cc_number = | 967 view->GetTextContentsOfInput(CREDIT_CARD_NUMBER)); |
| 982 controller()->RequestedFieldsForSection(SECTION_CC_BILLING)[0]; | |
| 983 EXPECT_EQ(cc_number.type, CREDIT_CARD_NUMBER); | |
| 984 EXPECT_EQ(ASCIIToUTF16("4111111111111111"), | |
| 985 view->GetTextContentsOfInput(cc_number)); | |
| 986 } | |
| 987 | 968 |
| 988 // The invalid data should be dropped. | 969 // The invalid data should be dropped. |
| 989 EXPECT_TRUE(view->GetTextContentsOfInput(shipping_zip).empty()); | 970 EXPECT_TRUE(view->GetTextContentsOfInput(ADDRESS_HOME_ZIP).empty()); |
| 990 | 971 |
| 991 // Switch back to Autofill. | 972 // Switch back to Autofill. |
| 992 ui::MenuModel* account_chooser = controller()->MenuModelForAccountChooser(); | 973 ui::MenuModel* account_chooser = controller()->MenuModelForAccountChooser(); |
| 993 account_chooser->ActivatedAt(account_chooser->GetItemCount() - 1); | 974 account_chooser->ActivatedAt(account_chooser->GetItemCount() - 1); |
| 994 ASSERT_FALSE(controller()->IsPayingWithWallet()); | 975 ASSERT_FALSE(controller()->IsPayingWithWallet()); |
| 995 | 976 |
| 996 { | 977 // The valid data should still be preserved when switched back. |
| 997 // The valid data should still be preserved when switched back. | 978 EXPECT_EQ(ASCIIToUTF16("4111111111111111"), |
| 998 const DetailInput& cc_number = | 979 view->GetTextContentsOfInput(CREDIT_CARD_NUMBER)); |
| 999 controller()->RequestedFieldsForSection(SECTION_CC)[0]; | |
| 1000 EXPECT_EQ(cc_number.type, CREDIT_CARD_NUMBER); | |
| 1001 EXPECT_EQ(ASCIIToUTF16("4111111111111111"), | |
| 1002 view->GetTextContentsOfInput(cc_number)); | |
| 1003 } | |
| 1004 } | 980 } |
| 1005 #endif // defined(TOOLKIT_VIEWS) || defined(OS_MACOSX) | 981 #endif // defined(TOOLKIT_VIEWS) || defined(OS_MACOSX) |
| 1006 | 982 |
| 1007 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, | 983 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, |
| 1008 GeneratedCardLastFourAfterVerifyCvv) { | 984 GeneratedCardLastFourAfterVerifyCvv) { |
| 1009 controller()->OnDidFetchWalletCookieValue(std::string()); | 985 controller()->OnDidFetchWalletCookieValue(std::string()); |
| 1010 | 986 |
| 1011 scoped_ptr<wallet::WalletItems> wallet_items = | 987 scoped_ptr<wallet::WalletItems> wallet_items = |
| 1012 wallet::GetTestWalletItems(wallet::AMEX_DISALLOWED); | 988 wallet::GetTestWalletItems(wallet::AMEX_DISALLOWED); |
| 1013 wallet_items->AddInstrument(wallet::GetTestMaskedInstrument()); | 989 wallet_items->AddInstrument(wallet::GetTestMaskedInstrument()); |
| (...skipping 203 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1217 ASSERT_TRUE(card.IsVerified()); | 1193 ASSERT_TRUE(card.IsVerified()); |
| 1218 | 1194 |
| 1219 // Add the card and check that there's a menu for that section. | 1195 // Add the card and check that there's a menu for that section. |
| 1220 controller()->GetTestingManager()->AddTestingCreditCard(&card); | 1196 controller()->GetTestingManager()->AddTestingCreditCard(&card); |
| 1221 ASSERT_TRUE(controller()->MenuModelForSection(SECTION_CC)); | 1197 ASSERT_TRUE(controller()->MenuModelForSection(SECTION_CC)); |
| 1222 | 1198 |
| 1223 // Select the invalid, suggested card from the menu. | 1199 // Select the invalid, suggested card from the menu. |
| 1224 controller()->MenuModelForSection(SECTION_CC)->ActivatedAt(0); | 1200 controller()->MenuModelForSection(SECTION_CC)->ActivatedAt(0); |
| 1225 EXPECT_TRUE(controller()->IsEditingExistingData(SECTION_CC)); | 1201 EXPECT_TRUE(controller()->IsEditingExistingData(SECTION_CC)); |
| 1226 | 1202 |
| 1227 const DetailInputs& inputs = | |
| 1228 controller()->RequestedFieldsForSection(SECTION_CC); | |
| 1229 const DetailInput& cc_exp_month = inputs[1]; | |
| 1230 ASSERT_EQ(CREDIT_CARD_EXP_MONTH, cc_exp_month.type); | |
| 1231 | |
| 1232 // Get the contents of the combobox of the credit card's expiration month. | 1203 // Get the contents of the combobox of the credit card's expiration month. |
| 1233 TestableAutofillDialogView* view = controller()->GetTestableView(); | 1204 TestableAutofillDialogView* view = controller()->GetTestableView(); |
| 1234 base::string16 cc_exp_month_text = view->GetTextContentsOfInput(cc_exp_month); | 1205 base::string16 cc_exp_month_text = |
| 1206 view->GetTextContentsOfInput(CREDIT_CARD_EXP_MONTH); | |
| 1235 | 1207 |
| 1236 // Select "New X..." from the suggestion menu to clear the section's inputs. | 1208 // Select "New X..." from the suggestion menu to clear the section's inputs. |
| 1237 controller()->MenuModelForSection(SECTION_CC)->ActivatedAt(1); | 1209 controller()->MenuModelForSection(SECTION_CC)->ActivatedAt(1); |
| 1238 EXPECT_FALSE(controller()->IsEditingExistingData(SECTION_CC)); | 1210 EXPECT_FALSE(controller()->IsEditingExistingData(SECTION_CC)); |
| 1239 | 1211 |
| 1240 // Ensure that the credit card expiration month has changed. | 1212 // Ensure that the credit card expiration month has changed. |
| 1241 EXPECT_NE(cc_exp_month_text, view->GetTextContentsOfInput(cc_exp_month)); | 1213 EXPECT_NE(cc_exp_month_text, |
| 1214 view->GetTextContentsOfInput(CREDIT_CARD_EXP_MONTH)); | |
| 1242 } | 1215 } |
| 1243 | 1216 |
| 1244 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, TabOpensToJustRight) { | 1217 IN_PROC_BROWSER_TEST_F(AutofillDialogControllerTest, TabOpensToJustRight) { |
| 1245 ASSERT_TRUE(browser()->is_type_tabbed()); | 1218 ASSERT_TRUE(browser()->is_type_tabbed()); |
| 1246 | 1219 |
| 1247 // Tabs should currently be: / rAc() \. | 1220 // Tabs should currently be: / rAc() \. |
| 1248 content::WebContents* dialog_invoker = controller()->GetWebContents(); | 1221 content::WebContents* dialog_invoker = controller()->GetWebContents(); |
| 1249 EXPECT_EQ(dialog_invoker, GetActiveWebContents()); | 1222 EXPECT_EQ(dialog_invoker, GetActiveWebContents()); |
| 1250 | 1223 |
| 1251 TabStripModel* tab_strip = browser()->tab_strip_model(); | 1224 TabStripModel* tab_strip = browser()->tab_strip_model(); |
| (...skipping 165 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1417 MAYBE_DoesntWorkOnBrokenHttps) { | 1390 MAYBE_DoesntWorkOnBrokenHttps) { |
| 1418 net::SpawnedTestServer https_server( | 1391 net::SpawnedTestServer https_server( |
| 1419 net::SpawnedTestServer::TYPE_HTTPS, | 1392 net::SpawnedTestServer::TYPE_HTTPS, |
| 1420 SSLOptions(SSLOptions::CERT_EXPIRED), | 1393 SSLOptions(SSLOptions::CERT_EXPIRED), |
| 1421 base::FilePath(FILE_PATH_LITERAL("chrome/test/data"))); | 1394 base::FilePath(FILE_PATH_LITERAL("chrome/test/data"))); |
| 1422 ASSERT_TRUE(https_server.Start()); | 1395 ASSERT_TRUE(https_server.Start()); |
| 1423 EXPECT_FALSE(RunTestPage(https_server)); | 1396 EXPECT_FALSE(RunTestPage(https_server)); |
| 1424 } | 1397 } |
| 1425 | 1398 |
| 1426 } // namespace autofill | 1399 } // namespace autofill |
| OLD | NEW |