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

Unified Diff: components/autofill/core/browser/autofill_field_unittest.cc

Issue 361833004: autofill: be more open minded about filling in states in <option>s. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 6 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/autofill/core/browser/autofill_field_unittest.cc
diff --git a/components/autofill/core/browser/autofill_field_unittest.cc b/components/autofill/core/browser/autofill_field_unittest.cc
index c4916d0830040ed56c33e725205786a7419744f6..c326dcd3f8825444af64521f6d7fe1157e2abd33 100644
--- a/components/autofill/core/browser/autofill_field_unittest.cc
+++ b/components/autofill/core/browser/autofill_field_unittest.cc
@@ -218,7 +218,7 @@ TEST(AutofillFieldTest, FillSelectControlWithFullStateNames) {
EXPECT_EQ(ASCIIToUTF16("California"), field.value);
}
-TEST(AutofillFieldTest, FillSelectControlWithWithAbbreviateStateNames) {
+TEST(AutofillFieldTest, FillSelectControlWithAbbreviateStateNames) {
const char* const kStates[] = {
"AL", "CA"
};
@@ -232,6 +232,67 @@ TEST(AutofillFieldTest, FillSelectControlWithWithAbbreviateStateNames) {
EXPECT_EQ(ASCIIToUTF16("CA"), field.value);
}
+TEST(AutofillFieldTest, FillSelectControlWithInexactFullStateNames) {
+ {
+ const char* const kStates[] = {
+ "CA - California", "NC - North Carolina",
Dan Beam 2014/07/01 00:34:32 can you reverse the order of these?
Ilya Sherman 2014/07/01 00:59:08 (Or, alternately, include an empty default item.)
Evan Stade 2014/07/01 01:04:56 I don't understand the purpose of either request.
Ilya Sherman 2014/07/01 01:17:47 My reasoning, which might or might not match Dan's
Dan Beam 2014/07/01 01:18:46 it currently looks like this test will select "CA
Evan Stade 2014/07/01 18:59:26 The main point of the test is to make sure "CA - C
Evan Stade 2014/07/01 23:08:52 But other tests (such as the one that uses kNotSta
+ };
+ AutofillField field(
+ GenerateSelectFieldWithOptions(kStates, arraysize(kStates)),
+ base::string16());
+ field.set_heuristic_type(ADDRESS_HOME_STATE);
+
+ AutofillField::FillFormField(field, ASCIIToUTF16("California"), "en-US",
+ &field);
+ EXPECT_EQ(ASCIIToUTF16("CA - California"), field.value);
+ }
+
+ // Tests that substring matches work for full state names.
+ {
+ const char* const kStates[] = {
+ "California.", "North Carolina.",
+ };
+ AutofillField field(
+ GenerateSelectFieldWithOptions(kStates, arraysize(kStates)),
+ base::string16());
+ field.set_heuristic_type(ADDRESS_HOME_STATE);
+
+ AutofillField::FillFormField(field, ASCIIToUTF16("California"), "en-US",
+ &field);
+ EXPECT_EQ(ASCIIToUTF16("California."), field.value);
+ }
+}
+
+TEST(AutofillFieldTest, FillSelectControlWithInexactAbbreviations) {
+ {
+ const char* const kStates[] = {
+ "NC - North Carolina", "CA - California",
+ };
+ AutofillField field(
+ GenerateSelectFieldWithOptions(kStates, arraysize(kStates)),
+ base::string16());
+ field.set_heuristic_type(ADDRESS_HOME_STATE);
+
+ AutofillField::FillFormField(field, ASCIIToUTF16("CA"), "en-US",
+ &field);
+ EXPECT_EQ(ASCIIToUTF16("CA - California"), field.value);
+ }
+
+ {
+ const char* const kNotStates[] = {
+ "NCNCA", "SCNCA",
+ };
+ AutofillField field(
+ GenerateSelectFieldWithOptions(kNotStates, arraysize(kNotStates)),
+ base::string16());
+ field.set_heuristic_type(ADDRESS_HOME_STATE);
+
+ AutofillField::FillFormField(field, ASCIIToUTF16("NC"), "en-US",
+ &field);
+ EXPECT_EQ(base::string16(), field.value);
+ }
+}
+
TEST(AutofillFieldTest, FillSelectControlWithNumericMonth) {
const char* const kMonthsNumeric[] = {
"01", "02", "03", "04", "05", "06", "07", "08", "09", "10", "11", "12",

Powered by Google App Engine
This is Rietveld 408576698