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 "base/basictypes.h" | 5 #include "base/basictypes.h" |
| 6 #include "base/guid.h" | 6 #include "base/guid.h" |
| 7 #include "base/memory/scoped_ptr.h" | 7 #include "base/memory/scoped_ptr.h" |
| 8 #include "base/memory/scoped_vector.h" | 8 #include "base/memory/scoped_vector.h" |
| 9 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
| 10 #include "base/strings/string16.h" | 10 #include "base/strings/string16.h" |
| (...skipping 880 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 891 profile.SetInfo(AutofillType(ADDRESS_HOME_STATE), | 891 profile.SetInfo(AutofillType(ADDRESS_HOME_STATE), |
| 892 ASCIIToUTF16("CA"), | 892 ASCIIToUTF16("CA"), |
| 893 "en-US"); | 893 "en-US"); |
| 894 EXPECT_FALSE(profile.GetInfo(full_address, "en-US").empty()); | 894 EXPECT_FALSE(profile.GetInfo(full_address, "en-US").empty()); |
| 895 profile.SetInfo(AutofillType(ADDRESS_HOME_COUNTRY), | 895 profile.SetInfo(AutofillType(ADDRESS_HOME_COUNTRY), |
| 896 base::string16(), | 896 base::string16(), |
| 897 "en-US"); | 897 "en-US"); |
| 898 EXPECT_TRUE(profile.GetInfo(full_address, "en-US").empty()); | 898 EXPECT_TRUE(profile.GetInfo(full_address, "en-US").empty()); |
| 899 } | 899 } |
| 900 | 900 |
| 901 TEST(AutofillProfileTest, OverwriteOrAppendNames) { | |
| 902 AutofillProfile a(base::GenerateGUID(), "https://www.example.com"); | |
| 903 test::SetProfileInfo(&a, | |
| 904 "Marion", | |
| 905 "Mitchell", | |
| 906 "Morrison", | |
| 907 "marion@me.xyz", | |
| 908 "Fox", | |
| 909 "123 Zoo St.", | |
| 910 "unit 5", | |
| 911 "Hollywood", | |
| 912 "CA", | |
| 913 "91601", | |
| 914 "US", | |
| 915 "12345678910"); | |
|
Ilya Sherman
2014/05/31 00:34:41
nit: Please only set the relevant fields, i.e. the
Pritam Nikam
2014/05/31 10:30:41
Done.
| |
| 916 | |
| 917 NameInfo name; | |
| 918 std::vector<NameInfo> names; | |
| 919 std::vector<base::string16> name_list; | |
| 920 | |
| 921 a.GetRawMultiInfo(NAME_FULL, &name_list); | |
| 922 ASSERT_EQ(1U, name_list.size()); | |
| 923 | |
| 924 // Case 1: Identical full names | |
| 925 // Case 1A: Prefer with more info - 2 word last-name | |
| 926 // overwrite existing name as {first||last1 last2} | |
| 927 name.SetRawInfo(NAME_FIRST, ASCIIToUTF16("Marion")); | |
| 928 name.SetRawInfo(NAME_MIDDLE, base::string16()); | |
| 929 name.SetRawInfo(NAME_LAST, ASCIIToUTF16("Mitchell Morrison")); | |
| 930 names.push_back(name); | |
| 931 | |
| 932 a.OverwriteOrAppendNames(names); | |
| 933 a.GetRawMultiInfo(NAME_FULL, &name_list); | |
| 934 ASSERT_EQ(1U, name_list.size()); | |
| 935 | |
| 936 // Case 1B: profile name with parsed tokens pased as first_, middle_ & last_ | |
| 937 // Don't add to the list - {first|middle|last} | |
| 938 base::string16 full_name = name.GetRawInfo(NAME_FULL); | |
| 939 name.SetRawInfo(NAME_FULL, full_name); | |
| 940 names[0] = name; | |
| 941 | |
| 942 a.OverwriteOrAppendNames(names); | |
| 943 a.GetRawMultiInfo(NAME_FULL, &name_list); | |
| 944 ASSERT_EQ(1U, name_list.size()); | |
| 945 | |
| 946 // Case 1C: Prefer with more info - 2 word first-name | |
| 947 // append as new name to the list - {first1 first2||last} | |
| 948 name.SetRawInfo(NAME_FIRST, ASCIIToUTF16("Marion Mitchell")); | |
| 949 name.SetRawInfo(NAME_MIDDLE, base::string16()); | |
| 950 name.SetRawInfo(NAME_LAST, ASCIIToUTF16("Morrison")); | |
| 951 names[0] = name; | |
| 952 | |
| 953 a.OverwriteOrAppendNames(names); | |
| 954 a.GetRawMultiInfo(NAME_FULL, &name_list); | |
| 955 ASSERT_EQ(2U, name_list.size()); | |
| 956 | |
| 957 // Case 2: Unique names | |
| 958 // append name to the list | |
| 959 name.SetRawInfo(NAME_FULL, ASCIIToUTF16("Marion M. Morrison")); | |
| 960 names[0] = name; | |
| 961 | |
| 962 a.OverwriteOrAppendNames(names); | |
| 963 a.GetRawMultiInfo(NAME_FULL, &name_list); | |
| 964 ASSERT_EQ(3U, name_list.size()); | |
| 965 } | |
|
Ilya Sherman
2014/05/31 00:34:41
This test code is somewhat fragile and hard to fol
Pritam Nikam
2014/05/31 10:30:41
Done.
| |
| 901 } // namespace autofill | 966 } // namespace autofill |
| OLD | NEW |