Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 <algorithm> | 5 #include <algorithm> |
| 6 #include <vector> | 6 #include <vector> |
| 7 | 7 |
| 8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 9 #include "base/format_macros.h" | 9 #include "base/format_macros.h" |
| 10 #include "base/memory/ref_counted.h" | 10 #include "base/memory/ref_counted.h" |
| (...skipping 3055 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 3066 else if (form.fields[i].name == ASCIIToUTF16("state")) | 3066 else if (form.fields[i].name == ASCIIToUTF16("state")) |
| 3067 form.fields[i].value = ASCIIToUTF16("Texas"); | 3067 form.fields[i].value = ASCIIToUTF16("Texas"); |
| 3068 else if (form.fields[i].name == ASCIIToUTF16("zipcode")) | 3068 else if (form.fields[i].name == ASCIIToUTF16("zipcode")) |
| 3069 form.fields[i].value = ASCIIToUTF16("77401"); | 3069 form.fields[i].value = ASCIIToUTF16("77401"); |
| 3070 else if (form.fields[i].name == ASCIIToUTF16("country")) | 3070 else if (form.fields[i].name == ASCIIToUTF16("country")) |
| 3071 form.fields[i].value = ASCIIToUTF16("US"); | 3071 form.fields[i].value = ASCIIToUTF16("US"); |
| 3072 } | 3072 } |
| 3073 autofill_manager_->OnFormSubmitted(form); | 3073 autofill_manager_->OnFormSubmitted(form); |
| 3074 } | 3074 } |
| 3075 | 3075 |
| 3076 // Test that suggestion tokens (substrings separated by characters from " | |
|
please use gerrit instead
2015/06/29 22:06:29
Please be more specific. For example, 'Verify that
Pritam Nikam
2015/06/30 15:05:50
Done.
| |
| 3077 // .,-_@") are matched against field contents. | |
| 3078 TEST_F(AutofillManagerTest, DisplaySuggestionsWithMatchingTokens) { | |
| 3079 // Token matching is currently behind a flag. | |
| 3080 base::CommandLine::ForCurrentProcess()->AppendSwitch( | |
| 3081 autofill::switches::kEnableSuggestionsWithSubstringMatch); | |
| 3082 | |
| 3083 // Set up our form data. | |
| 3084 FormData form; | |
| 3085 test::CreateTestAddressFormData(&form); | |
| 3086 std::vector<FormData> forms(1, form); | |
| 3087 FormsSeen(forms); | |
| 3088 | |
| 3089 // Simulate displaying suggestions for field contents "gmail", check that | |
| 3090 // matching ones are displayed. | |
| 3091 FormFieldData field; | |
| 3092 test::CreateTestFormField("Email", "email", "gmail", "email", &field); | |
| 3093 GetAutofillSuggestions(form, field); | |
| 3094 AutocompleteSuggestionsReturned(std::vector<base::string16>()); | |
| 3095 | |
| 3096 external_delegate_->CheckSuggestions( | |
| 3097 kDefaultPageID, | |
| 3098 Suggestion("theking@gmail.com", "3734 Elvis Presley Blvd.", "", 1), | |
| 3099 Suggestion("buddy@gmail.com", "123 Apple St.", "", 2)); | |
| 3100 } | |
| 3101 | |
| 3102 // Test that suggestion tokens (substrings separated by characters from " | |
| 3103 // .,-_@") are matched against field contents ignoring their case. | |
|
please use gerrit instead
2015/06/29 22:06:29
Please be more specific. For example, 'Verify that
Pritam Nikam
2015/06/30 15:05:50
Done.
| |
| 3104 TEST_F(AutofillManagerTest, DisplaySuggestionsWithMatchingTokens_CaseIgnored) { | |
| 3105 // Token matching is currently behind a flag. | |
| 3106 base::CommandLine::ForCurrentProcess()->AppendSwitch( | |
| 3107 autofill::switches::kEnableSuggestionsWithSubstringMatch); | |
| 3108 | |
| 3109 // Set up our form data. | |
| 3110 FormData form; | |
| 3111 test::CreateTestAddressFormData(&form); | |
| 3112 std::vector<FormData> forms(1, form); | |
| 3113 FormsSeen(forms); | |
| 3114 | |
| 3115 // Simulate displaying suggestions for field contents "apple", check that | |
| 3116 // matching one is displayed. | |
| 3117 FormFieldData field; | |
| 3118 test::CreateTestFormField("Address Line 2", "addr2", "apple", "text", &field); | |
| 3119 GetAutofillSuggestions(form, field); | |
| 3120 AutocompleteSuggestionsReturned(std::vector<base::string16>()); | |
| 3121 | |
| 3122 external_delegate_->CheckSuggestions( | |
| 3123 kDefaultPageID, | |
| 3124 Suggestion("123 Apple St., unit 6", "123 Apple St.", "", 1)); | |
| 3125 } | |
| 3126 | |
| 3127 // Test that suggestions which do not have a prefix match or prefix-token match | |
|
please use gerrit instead
2015/06/29 22:06:29
Please be more specific. For example, 'Verify that
Pritam Nikam
2015/06/30 15:05:50
Done.
| |
| 3128 // with the field contents are not matched. | |
| 3129 TEST_F(AutofillManagerTest, NoSuggestionForNonPrefixTokenMatch) { | |
| 3130 // Token matching is currently behind a flag. | |
| 3131 base::CommandLine::ForCurrentProcess()->AppendSwitch( | |
| 3132 autofill::switches::kEnableSuggestionsWithSubstringMatch); | |
| 3133 | |
| 3134 // Set up our form data. | |
| 3135 FormData form; | |
| 3136 test::CreateTestAddressFormData(&form); | |
| 3137 std::vector<FormData> forms(1, form); | |
| 3138 FormsSeen(forms); | |
| 3139 | |
| 3140 // Simulate displaying suggestions for field contents "mail". Check that none | |
| 3141 // appear, because none has a token with a prefix "mail". | |
| 3142 FormFieldData field; | |
| 3143 test::CreateTestFormField("Email", "email", "mail", "email", &field); | |
| 3144 GetAutofillSuggestions(form, field); | |
| 3145 EXPECT_FALSE(external_delegate_->on_suggestions_returned_seen()); | |
| 3146 } | |
| 3147 | |
| 3148 // Test that the credit card holder name suggestion tokens (substrings separated | |
| 3149 // by characters from " .,-_@") are matched against field contents. | |
| 3150 TEST_F(AutofillManagerTest, DisplayCreditCardSuggestionsWithMatchingTokens) { | |
| 3151 // Token matching is currently behind a flag. | |
| 3152 base::CommandLine::ForCurrentProcess()->AppendSwitch( | |
| 3153 autofill::switches::kEnableSuggestionsWithSubstringMatch); | |
| 3154 | |
| 3155 // Set up our form data. | |
| 3156 FormData form; | |
| 3157 CreateTestCreditCardFormData(&form, true, false); | |
| 3158 std::vector<FormData> forms(1, form); | |
| 3159 FormsSeen(forms); | |
| 3160 | |
| 3161 FormFieldData field; | |
| 3162 test::CreateTestFormField("Name on Card", "nameoncard", "pres", "text", | |
| 3163 &field); | |
| 3164 GetAutofillSuggestions(form, field); | |
| 3165 | |
| 3166 // No suggestions provided, so send an empty vector as the results. | |
| 3167 // This triggers the combined message send. | |
| 3168 AutocompleteSuggestionsReturned(std::vector<base::string16>()); | |
| 3169 | |
| 3170 // Simulate displaying suggestions for field contents "pres", check that | |
| 3171 // matching one is displayed. | |
| 3172 external_delegate_->CheckSuggestions( | |
| 3173 kDefaultPageID, Suggestion("Elvis Presley", "*3456", kVisaCard, | |
| 3174 autofill_manager_->GetPackedCreditCardID(4))); | |
| 3175 } | |
| 3176 | |
| 3177 // Test that the credit card holder name suggestions which do not have a prefix | |
| 3178 // match or prefix-token match with the field contents are not matched. | |
| 3179 TEST_F(AutofillManagerTest, NoCreditCardSuggestionsForNonPrefixTokenMatch) { | |
| 3180 // Token matching is currently behind a flag. | |
| 3181 base::CommandLine::ForCurrentProcess()->AppendSwitch( | |
| 3182 autofill::switches::kEnableSuggestionsWithSubstringMatch); | |
| 3183 | |
| 3184 // Set up our form data. | |
| 3185 FormData form; | |
| 3186 CreateTestCreditCardFormData(&form, true, false); | |
| 3187 std::vector<FormData> forms(1, form); | |
| 3188 FormsSeen(forms); | |
| 3189 | |
| 3190 // Simulate displaying suggestions for field contents "lvis". Check that none | |
| 3191 // appear, because none has a token with a prefix "lvis". | |
| 3192 FormFieldData field; | |
| 3193 test::CreateTestFormField("Name on Card", "nameoncard", "lvis", "text", | |
| 3194 &field); | |
| 3195 GetAutofillSuggestions(form, field); | |
| 3196 EXPECT_FALSE(external_delegate_->on_suggestions_returned_seen()); | |
| 3197 } | |
| 3198 | |
| 3199 // Test that suggestion tokens (substrings separated by characters from | |
| 3200 // " .,-_@") are ordered prefixes precede substring matched. | |
| 3201 TEST_F(AutofillManagerTest, | |
| 3202 DisplaySuggestionsWithPrefixesPrecedeSubstringMatched) { | |
| 3203 // Token matching is currently behind a flag. | |
| 3204 base::CommandLine::ForCurrentProcess()->AppendSwitch( | |
| 3205 autofill::switches::kEnableSuggestionsWithSubstringMatch); | |
| 3206 | |
| 3207 // Set up our form data. | |
| 3208 FormData form; | |
| 3209 test::CreateTestAddressFormData(&form); | |
| 3210 std::vector<FormData> forms(1, form); | |
| 3211 FormsSeen(forms); | |
| 3212 | |
| 3213 AutofillProfile* profile1 = new AutofillProfile; | |
| 3214 profile1->set_guid("00000000-0000-0000-0000-000000000103"); | |
| 3215 profile1->SetInfo(AutofillType(NAME_FIRST), ASCIIToUTF16("Robin"), "en-US"); | |
| 3216 profile1->SetInfo(AutofillType(NAME_MIDDLE), ASCIIToUTF16("Adam Smith"), | |
| 3217 "en-US"); | |
| 3218 profile1->SetInfo(AutofillType(NAME_LAST), ASCIIToUTF16("Grimes"), "en-US"); | |
| 3219 profile1->SetInfo(AutofillType(ADDRESS_HOME_LINE1), | |
| 3220 ASCIIToUTF16("1234 Smith Blvd."), "en-US"); | |
| 3221 autofill_manager_->AddProfile(profile1); | |
| 3222 | |
| 3223 AutofillProfile* profile2 = new AutofillProfile; | |
| 3224 profile2->set_guid("00000000-0000-0000-0000-000000000124"); | |
| 3225 profile2->SetInfo(AutofillType(NAME_FIRST), ASCIIToUTF16("Carl"), "en-US"); | |
| 3226 profile2->SetInfo(AutofillType(NAME_MIDDLE), ASCIIToUTF16("Shawn Smith"), | |
| 3227 "en-US"); | |
| 3228 profile2->SetInfo(AutofillType(NAME_LAST), ASCIIToUTF16("Grimes"), "en-US"); | |
| 3229 profile2->SetInfo(AutofillType(ADDRESS_HOME_LINE1), | |
| 3230 ASCIIToUTF16("1234 Smith Blvd."), "en-US"); | |
| 3231 autofill_manager_->AddProfile(profile2); | |
| 3232 | |
| 3233 // Simulate displaying suggestions for field contents "S", check that | |
| 3234 // matching ones are displayed. | |
| 3235 FormFieldData field; | |
| 3236 test::CreateTestFormField("Middle Name", "middlename", "S", "text", &field); | |
| 3237 GetAutofillSuggestions(form, field); | |
| 3238 | |
| 3239 // No suggestions provided, so send an empty vector as the results. | |
| 3240 // This triggers the combined message send. | |
| 3241 AutocompleteSuggestionsReturned(std::vector<base::string16>()); | |
| 3242 | |
| 3243 external_delegate_->CheckSuggestions( | |
| 3244 kDefaultPageID, | |
| 3245 Suggestion("Shawn Smith", "1234 Smith Blvd., Robin Adam Smith Grimes", "", | |
| 3246 1), | |
| 3247 Suggestion("Adam Smith", "1234 Smith Blvd., Carl Shawn Smith Grimes", "", | |
| 3248 2)); | |
| 3249 } | |
| 3250 | |
| 3076 } // namespace autofill | 3251 } // namespace autofill |
| OLD | NEW |