Chromium Code Reviews| Index: components/autofill/core/browser/autofill_manager_unittest.cc |
| diff --git a/components/autofill/core/browser/autofill_manager_unittest.cc b/components/autofill/core/browser/autofill_manager_unittest.cc |
| index c556bf92cee944cecff7142fa7799a5ebb7a733b..303e8dcf3521c3db80c3a8ac9388fbe8ab94ed96 100644 |
| --- a/components/autofill/core/browser/autofill_manager_unittest.cc |
| +++ b/components/autofill/core/browser/autofill_manager_unittest.cc |
| @@ -15,6 +15,7 @@ |
| #include "base/run_loop.h" |
| #include "base/strings/string16.h" |
| #include "base/strings/string_number_conversions.h" |
| +#include "base/strings/string_util.h" |
| #include "base/strings/stringprintf.h" |
| #include "base/strings/utf_string_conversions.h" |
| #include "base/time/time.h" |
| @@ -898,7 +899,7 @@ TEST_F(AutofillManagerTest, GetCreditCardSuggestionsMatchCharacter) { |
| FormsSeen(forms); |
| FormFieldData field; |
| - test::CreateTestFormField("Card Number", "cardnumber", "4", "text", &field); |
| + test::CreateTestFormField("Card Number", "cardnumber", "78", "text", &field); |
| GetAutofillSuggestions(form, field); |
| // No suggestions provided, so send an empty vector as the results. |
| @@ -2988,4 +2989,73 @@ TEST_F(AutofillManagerTest, TestExternalDelegate) { |
| EXPECT_TRUE(external_delegate_->on_query_seen()); |
| } |
| +// Test to verify suggestions appears for forms having credit card number split |
| +// across fields. |
| +TEST_F(AutofillManagerTest, GetCreditCardSuggestionsForNumberSpitAcrossFields) { |
| + // Set up our form data with credit card number split across fields. |
| + FormData form; |
| + CreateTestCreditCardFormData(&form, true, false); |
|
Ilya Sherman
2014/10/30 22:58:55
Please remove this call as well, and instead const
Pritam Nikam
2014/10/31 06:59:33
Done.
|
| + |
| + // Remove existing card number field. |
| + form.fields.erase(form.fields.begin() + 1); |
| + |
| + // Add new 4 |card_number_field|s to the |form|. |
| + FormFieldData card_number_field; |
| + card_number_field.max_length = 4; |
| + test::CreateTestFormField( |
| + "Card Number", "cardnumber_1", "", "text", &card_number_field); |
| + form.fields.insert(form.fields.begin() + 1, card_number_field); |
| + |
| + test::CreateTestFormField("", "cardnumber_2", "", "text", &card_number_field); |
| + form.fields.insert(form.fields.begin() + 2, card_number_field); |
| + |
| + test::CreateTestFormField("", "cardnumber_3", "", "text", &card_number_field); |
| + form.fields.insert(form.fields.begin() + 3, card_number_field); |
| + |
| + test::CreateTestFormField("", "cardnumber_4", "", "text", &card_number_field); |
| + form.fields.insert(form.fields.begin() + 4, card_number_field); |
| + |
| + std::vector<FormData> forms(1, form); |
| + FormsSeen(forms); |
| + |
| + // Fill the credit card details. |
|
Ilya Sherman
2014/10/30 22:58:55
I'm still not sure why you're filling the form as
Pritam Nikam
2014/10/31 06:59:33
Yes, you are right, we do have testcases for the f
Ilya Sherman
2014/10/31 22:49:59
Hmm, do we really need the field to be autofilled?
|
| + GUIDPair guid("00000000-0000-0000-0000-000000000004", 0); |
| + GUIDPair empty(std::string(), 0); |
| + int response_page_id = 0; |
| + FormData response_data; |
| + FillAutofillFormDataAndSaveResults(kDefaultPageID, |
| + form, |
| + *form.fields.begin(), |
| + PackGUIDs(guid, empty), |
| + &response_page_id, |
| + &response_data); |
| + |
| + ASSERT_EQ(7U, response_data.fields.size()); |
| + |
| + // Verify whether suggestions are populated correctly for one of the middle |
| + // credit card number fields. |
| + FormFieldData number_field = response_data.fields[3]; |
| + |
| + // Suggested card number 4234-5678-9012-3456. |
| + EXPECT_TRUE(StartsWith(number_field.value, ASCIIToUTF16("9012"), false)); |
| + |
| + // Get the suggestions for credit card |number_field|. |
| + GetAutofillSuggestions(form, number_field); |
| + |
| + // No suggestions provided, so send an empty vector as the results. |
| + // This triggers the combined message send. |
| + AutocompleteSuggestionsReturned(std::vector<base::string16>()); |
| + |
| + base::string16 expected_values[] = {ASCIIToUTF16("************3456")}; |
| + base::string16 expected_labels[] = {ASCIIToUTF16("04/12")}; |
| + base::string16 expected_icons[] = {ASCIIToUTF16(kVisaCard)}; |
| + int expected_unique_ids[] = {autofill_manager_->GetPackedCreditCardID(4)}; |
| + external_delegate_->CheckSuggestions(kDefaultPageID, |
| + arraysize(expected_values), |
| + expected_values, |
| + expected_labels, |
| + expected_icons, |
| + expected_unique_ids); |
| +} |
| + |
| } // namespace autofill |