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

Side by Side Diff: components/autofill/core/browser/form_structure_unittest.cc

Issue 1411363003: [Autofill] Always show available data when encountering autocomplete attributes (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressed mathp's comments Created 5 years, 2 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 unified diff | Download patch
OLDNEW
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 "components/autofill/core/browser/form_structure.h" 5 #include "components/autofill/core/browser/form_structure.h"
6 6
7 #include "base/command_line.h" 7 #include "base/command_line.h"
8 #include "base/memory/scoped_ptr.h" 8 #include "base/memory/scoped_ptr.h"
9 #include "base/metrics/field_trial.h" 9 #include "base/metrics/field_trial.h"
10 #include "base/strings/string_util.h" 10 #include "base/strings/string_util.h"
(...skipping 287 matching lines...) Expand 10 before | Expand all | Expand 10 after
298 298
299 field.label = ASCIIToUTF16("Country"); 299 field.label = ASCIIToUTF16("Country");
300 field.name = ASCIIToUTF16("country"); 300 field.name = ASCIIToUTF16("country");
301 field.form_control_type = "select-one"; 301 field.form_control_type = "select-one";
302 form.fields.push_back(field); 302 form.fields.push_back(field);
303 303
304 form_structure.reset(new FormStructure(form)); 304 form_structure.reset(new FormStructure(form));
305 EXPECT_TRUE(form_structure->ShouldBeParsed()); 305 EXPECT_TRUE(form_structure->ShouldBeParsed());
306 306
307 form.fields[0].form_control_type = "select-one"; 307 form.fields[0].form_control_type = "select-one";
308
308 // Now, no text fields. 309 // Now, no text fields.
309 form_structure.reset(new FormStructure(form)); 310 form_structure.reset(new FormStructure(form));
310 EXPECT_FALSE(form_structure->ShouldBeParsed()); 311 EXPECT_FALSE(form_structure->ShouldBeParsed());
311 } 312 }
312 313
314 // Tests that ShouldBeParsed returns true for a form containing less than three
315 // fields if at least one has an autocomplete attribute.
316 TEST_F(FormStructureTest, ShouldBeParsed_TwoFields_HasAutocomplete) {
317 scoped_ptr<FormStructure> form_structure;
318 FormData form;
319 FormFieldData field;
320
321 field.label = ASCIIToUTF16("Name");
322 field.name = ASCIIToUTF16("name");
323 field.form_control_type = "name";
324 field.autocomplete_attribute = "name";
325 form.fields.push_back(field);
326
327 field.label = ASCIIToUTF16("Address");
328 field.name = ASCIIToUTF16("Address");
329 field.form_control_type = "select-one";
330 field.autocomplete_attribute = "";
331 form.fields.push_back(field);
332
333 form_structure.reset(new FormStructure(form));
334 form_structure->ParseFieldTypesFromAutocompleteAttributes();
335 EXPECT_TRUE(form_structure->ShouldBeParsed());
336 }
337
313 TEST_F(FormStructureTest, HeuristicsContactInfo) { 338 TEST_F(FormStructureTest, HeuristicsContactInfo) {
314 scoped_ptr<FormStructure> form_structure; 339 scoped_ptr<FormStructure> form_structure;
315 FormData form; 340 FormData form;
316 341
317 FormFieldData field; 342 FormFieldData field;
318 field.form_control_type = "text"; 343 field.form_control_type = "text";
319 344
320 field.label = ASCIIToUTF16("First Name"); 345 field.label = ASCIIToUTF16("First Name");
321 field.name = ASCIIToUTF16("firstname"); 346 field.name = ASCIIToUTF16("firstname");
322 form.fields.push_back(field); 347 form.fields.push_back(field);
(...skipping 2526 matching lines...) Expand 10 before | Expand all | Expand 10 after
2849 field.autocomplete_attribute = "billing country"; 2874 field.autocomplete_attribute = "billing country";
2850 field.option_contents.push_back(ASCIIToUTF16("Down Under")); 2875 field.option_contents.push_back(ASCIIToUTF16("Down Under"));
2851 field.option_values.push_back(ASCIIToUTF16("AU")); 2876 field.option_values.push_back(ASCIIToUTF16("AU"));
2852 field.option_contents.push_back(ASCIIToUTF16("Fr")); 2877 field.option_contents.push_back(ASCIIToUTF16("Fr"));
2853 field.option_values.push_back(ASCIIToUTF16("")); 2878 field.option_values.push_back(ASCIIToUTF16(""));
2854 field.option_contents.push_back(ASCIIToUTF16("Germany")); 2879 field.option_contents.push_back(ASCIIToUTF16("Germany"));
2855 field.option_values.push_back(ASCIIToUTF16("GRMNY")); 2880 field.option_values.push_back(ASCIIToUTF16("GRMNY"));
2856 form_data.fields.push_back(field); 2881 form_data.fields.push_back(field);
2857 FormStructure form_structure(form_data); 2882 FormStructure form_structure(form_data);
2858 2883
2859 bool unused; 2884 form_structure.ParseFieldTypesFromAutocompleteAttributes();
2860 form_structure.ParseFieldTypesFromAutocompleteAttributes(&unused, &unused);
2861 2885
2862 // All values in <option> value= or contents are returned, set to upper case. 2886 // All values in <option> value= or contents are returned, set to upper case.
2863 std::set<base::string16> possible_values = 2887 std::set<base::string16> possible_values =
2864 form_structure.PossibleValues(ADDRESS_BILLING_COUNTRY); 2888 form_structure.PossibleValues(ADDRESS_BILLING_COUNTRY);
2865 EXPECT_EQ(5U, possible_values.size()); 2889 EXPECT_EQ(5U, possible_values.size());
2866 EXPECT_EQ(1U, possible_values.count(ASCIIToUTF16("AU"))); 2890 EXPECT_EQ(1U, possible_values.count(ASCIIToUTF16("AU")));
2867 EXPECT_EQ(1U, possible_values.count(ASCIIToUTF16("FR"))); 2891 EXPECT_EQ(1U, possible_values.count(ASCIIToUTF16("FR")));
2868 EXPECT_EQ(1U, possible_values.count(ASCIIToUTF16("DOWN UNDER"))); 2892 EXPECT_EQ(1U, possible_values.count(ASCIIToUTF16("DOWN UNDER")));
2869 EXPECT_EQ(1U, possible_values.count(ASCIIToUTF16("GERMANY"))); 2893 EXPECT_EQ(1U, possible_values.count(ASCIIToUTF16("GERMANY")));
2870 EXPECT_EQ(1U, possible_values.count(ASCIIToUTF16("GRMNY"))); 2894 EXPECT_EQ(1U, possible_values.count(ASCIIToUTF16("GRMNY")));
2871 EXPECT_EQ(0U, possible_values.count(ASCIIToUTF16("Fr"))); 2895 EXPECT_EQ(0U, possible_values.count(ASCIIToUTF16("Fr")));
2872 EXPECT_EQ(0U, possible_values.count(ASCIIToUTF16("DE"))); 2896 EXPECT_EQ(0U, possible_values.count(ASCIIToUTF16("DE")));
2873 2897
2874 // No field for the given type; empty value set. 2898 // No field for the given type; empty value set.
2875 EXPECT_EQ(0U, form_structure.PossibleValues(ADDRESS_HOME_COUNTRY).size()); 2899 EXPECT_EQ(0U, form_structure.PossibleValues(ADDRESS_HOME_COUNTRY).size());
2876 2900
2877 // A freeform input (<input>) allows any value (overriding other <select>s). 2901 // A freeform input (<input>) allows any value (overriding other <select>s).
2878 FormFieldData freeform_field; 2902 FormFieldData freeform_field;
2879 freeform_field.autocomplete_attribute = "billing country"; 2903 freeform_field.autocomplete_attribute = "billing country";
2880 form_data.fields.push_back(freeform_field); 2904 form_data.fields.push_back(freeform_field);
2881 FormStructure form_structure2(form_data); 2905 FormStructure form_structure2(form_data);
2882 form_structure2.ParseFieldTypesFromAutocompleteAttributes(&unused, &unused); 2906 form_structure2.ParseFieldTypesFromAutocompleteAttributes();
2883 EXPECT_EQ(0U, form_structure2.PossibleValues(ADDRESS_BILLING_COUNTRY).size()); 2907 EXPECT_EQ(0U, form_structure2.PossibleValues(ADDRESS_BILLING_COUNTRY).size());
2884 } 2908 }
2885 2909
2886 TEST_F(FormStructureTest, ParseQueryResponse) { 2910 TEST_F(FormStructureTest, ParseQueryResponse) {
2887 FormData form; 2911 FormData form;
2888 form.origin = GURL("http://foo.com"); 2912 form.origin = GURL("http://foo.com");
2889 FormFieldData field; 2913 FormFieldData field;
2890 field.form_control_type = "text"; 2914 field.form_control_type = "text";
2891 2915
2892 field.label = ASCIIToUTF16("fullname"); 2916 field.label = ASCIIToUTF16("fullname");
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after
2965 "</autofillqueryresponse>"; 2989 "</autofillqueryresponse>";
2966 2990
2967 FormStructure::ParseQueryResponse(response, forms.get(), nullptr); 2991 FormStructure::ParseQueryResponse(response, forms.get(), nullptr);
2968 2992
2969 ASSERT_GE(forms[0]->field_count(), 2U); 2993 ASSERT_GE(forms[0]->field_count(), 2U);
2970 EXPECT_EQ(NO_SERVER_DATA, forms[0]->field(0)->server_type()); 2994 EXPECT_EQ(NO_SERVER_DATA, forms[0]->field(0)->server_type());
2971 EXPECT_EQ(76, forms[0]->field(1)->server_type()); 2995 EXPECT_EQ(76, forms[0]->field(1)->server_type());
2972 } 2996 }
2973 2997
2974 } // namespace autofill 2998 } // namespace autofill
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698