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

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

Issue 374053007: Change PhoneNumber::SetInfo to only apply formatting where there is none (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: better way Created 6 years, 5 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 | Annotate | Revision Log
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 "base/message_loop/message_loop.h" 5 #include "base/message_loop/message_loop.h"
6 #include "base/strings/string16.h" 6 #include "base/strings/string16.h"
7 #include "base/strings/utf_string_conversions.h" 7 #include "base/strings/utf_string_conversions.h"
8 #include "components/autofill/core/browser/phone_number_i18n.h" 8 #include "components/autofill/core/browser/phone_number_i18n.h"
9 #include "testing/gtest/include/gtest/gtest.h" 9 #include "testing/gtest/include/gtest/gtest.h"
10 #include "third_party/libphonenumber/src/phonenumber_api.h" 10 #include "third_party/libphonenumber/src/phonenumber_api.h"
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
49 bool valid; 49 bool valid;
50 // Inputs. 50 // Inputs.
51 std::string input; 51 std::string input;
52 std::string assumed_region; 52 std::string assumed_region;
53 // Further expectations. 53 // Further expectations.
54 std::string number; 54 std::string number;
55 std::string city_code; 55 std::string city_code;
56 std::string country_code; 56 std::string country_code;
57 std::string deduced_region; 57 std::string deduced_region;
58 } test_cases[] = { 58 } test_cases[] = {
59 // Test for empty string. Should give back empty strings. 59 // Test for empty string. Should give back empty strings.
60 { false, "", "US" }, 60 {false, "", "US"},
61 // Test for string with less than 7 digits. Should give back empty strings. 61 // Test for string with less than 7 digits. Should give back empty
62 { false, "1234", "US" }, 62 // strings.
63 // Test for string with exactly 7 digits. 63 {false, "1234", "US"},
64 // Not a valid number - starts with 1 64 // Test for string with exactly 7 digits.
65 { false, "17134567", "US" }, 65 // Not a valid number - starts with 1
66 // Not a valid number - does not have area code. 66 {false, "17134567", "US"},
67 { false, "7134567", "US" }, 67 // Not a valid number - does not have area code.
68 // Valid Canadian toll-free number. 68 {false, "7134567", "US"},
69 { true, "3101234", "US", "3101234", "", "", "CA" }, 69 // Valid Canadian toll-free number.
70 // Test for string with greater than 7 digits but less than 10 digits. 70 {true, "3101234", "US", "3101234", "", "", "CA"},
71 // Should fail parsing in US. 71 // Test for string with greater than 7 digits but less than 10 digits.
72 { false, "123456789", "US" }, 72 // Should fail parsing in US.
73 // Test for string with greater than 7 digits but less than 10 digits and 73 {false, "123456789", "US"},
74 // separators. 74 // Test for string with greater than 7 digits but less than 10 digits
75 // Should fail parsing in US. 75 // and
76 { false, "12.345-6789", "US" }, 76 // separators.
77 // Test for string with exactly 10 digits. 77 // Should fail parsing in US.
78 // Should give back phone number and city code. 78 {false, "12.345-6789", "US"},
79 // This one going to fail because of the incorrect area code. 79 // Test for string with exactly 10 digits.
80 { false, "1234567890", "US" }, 80 // Should give back phone number and city code.
81 // This one going to fail because of the incorrect number (starts with 1). 81 // This one going to fail because of the incorrect area code.
82 { false, "6501567890", "US" }, 82 {false, "1234567890", "US"},
83 { true, "6504567890", "US", "4567890", "650", "", "US" }, 83 // This one going to fail because of the incorrect number (starts with
84 // Test for string with exactly 10 digits and separators. 84 // 1).
85 // Should give back phone number and city code. 85 {false, "6501567890", "US"},
86 { true, "(650) 456-7890", "US", "4567890", "650", "", "US" }, 86 {true, "6504567890", "US", "4567890", "650", "", "US"},
87 // Tests for string with over 10 digits. 87 // Test for string with exactly 10 digits and separators.
88 // 01 is incorrect prefix in the USA, and if we interpret 011 as prefix, the 88 // Should give back phone number and city code.
89 // rest is too short for international number - the parsing should fail. 89 {true, "(650) 456-7890", "US", "4567890", "650", "", "US"},
90 { false, "0116504567890", "US" }, 90 // Tests for string with over 10 digits.
91 // 011 is a correct "dial out" prefix in the USA - the parsing should 91 // 01 is incorrect prefix in the USA, and if we interpret 011 as prefix,
92 // succeed. 92 // the
93 { true, "01116504567890", "US", "4567890", "650", "1", "US" }, 93 // rest is too short for international number - the parsing should fail.
94 // 011 is a correct "dial out" prefix in the USA but the rest of the number 94 {false, "0116504567890", "US"},
95 // can't parse as a US number. 95 // 011 is a correct "dial out" prefix in the USA - the parsing should
96 { true, "01178124567890", "US", "4567890", "812", "7", "RU" }, 96 // succeed.
97 // Test for string with over 10 digits with separator characters. 97 {true, "01116504567890", "US", "4567890", "650", "1", "US"},
98 // Should give back phone number, city code, and country code. "011" is 98 // 011 is a correct "dial out" prefix in the USA but the rest of the
99 // US "dial out" code, which is discarded. 99 // number
100 { true, "(0111) 650-456.7890", "US", "4567890", "650", "1" , "US" }, 100 // can't parse as a US number.
101 // Now try phone from Czech republic - it has 00 dial out code, 420 country 101 {true, "01178124567890", "US", "4567890", "812", "7", "RU"},
102 // code and variable length area codes. 102 // Test for string with over 10 digits with separator characters.
103 { true, "+420 27-89.10.112", "US", "910112", "278", "420", "CZ" }, 103 // Should give back phone number, city code, and country code. "011" is
104 { false, "27-89.10.112", "US" }, 104 // US "dial out" code, which is discarded.
105 { true, "27-89.10.112", "CZ", "910112", "278", "", "CZ" }, 105 {true, "(0111) 650-456.7890", "US", "4567890", "650", "1", "US"},
106 { false, "420 57-89.10.112", "US" }, 106 // Now try phone from Czech republic - it has 00 dial out code, 420
107 { true, "420 57-89.10.112", "CZ", "910112", "578", "420", "CZ" }, 107 // country
108 // Parses vanity numbers. 108 // code and variable length area codes.
109 { true, "1-650-FLOWERS", "US", "3569377", "650", "1", "US" }, 109 {true, "+420 27-89.10.112", "US", "910112", "278", "420", "CZ"},
110 // 800 is not an area code, but the destination code. In our library these 110 {false, "27-89.10.112", "US"},
111 // codes should be treated the same as area codes. 111 {true, "27-89.10.112", "CZ", "910112", "278", "", "CZ"},
112 { true, "1-800-FLOWERS", "US", "3569377", "800", "1", "US" }, 112 {false, "420 57-89.10.112", "US"},
113 }; 113 {true, "420 57-89.10.112", "CZ", "910112", "578", "420", "CZ"},
114 // Parses vanity numbers.
115 {true, "1-650-FLOWERS", "US", "3569377", "650", "1", "US"},
116 // 800 is not an area code, but the destination code. In our library
117 // these
118 // codes should be treated the same as area codes.
119 {true, "1-800-FLOWERS", "US", "3569377", "800", "1", "US"},
120 // Don't add a country code where there was none.
121 {true, "(08) 450 777 7777", "DE", "7777777", "8450", "", "DE"},
122 };
114 123
115 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(test_cases); ++i) { 124 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(test_cases); ++i) {
116 SCOPED_TRACE("Testing phone number " + test_cases[i].input); 125 SCOPED_TRACE("Testing phone number " + test_cases[i].input);
117 126
118 base::string16 country_code, city_code, number; 127 base::string16 country_code, city_code, number;
119 std::string deduced_region; 128 std::string deduced_region;
120 ::i18n::phonenumbers::PhoneNumber unused_i18n_number; 129 ::i18n::phonenumbers::PhoneNumber unused_i18n_number;
121 EXPECT_EQ(test_cases[i].valid, 130 EXPECT_EQ(test_cases[i].valid,
122 ParsePhoneNumber(ASCIIToUTF16(test_cases[i].input), 131 ParsePhoneNumber(ASCIIToUTF16(test_cases[i].input),
123 test_cases[i].assumed_region, 132 test_cases[i].assumed_region,
(...skipping 117 matching lines...) Expand 10 before | Expand all | Expand 10 after
241 "en-US")); 250 "en-US"));
242 251
243 // Different numbers don't match. 252 // Different numbers don't match.
244 EXPECT_FALSE(PhoneNumbersMatch(ASCIIToUTF16("14158889999"), 253 EXPECT_FALSE(PhoneNumbersMatch(ASCIIToUTF16("14158889999"),
245 ASCIIToUTF16("1415888"), 254 ASCIIToUTF16("1415888"),
246 "US", 255 "US",
247 "en-US")); 256 "en-US"));
248 } 257 }
249 258
250 } // namespace autofill 259 } // namespace autofill
OLDNEW
« no previous file with comments | « components/autofill/core/browser/phone_number_i18n.cc ('k') | components/autofill/core/browser/phone_number_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698