summaryrefslogtreecommitdiff
path: root/android/PhoneNumberUtilsTest.cpp
diff options
context:
space:
mode:
authorFrancisco Pimenta <fpimenta@google.com>2017-07-12 09:52:58 -0700
committerFrancisco Pimenta <fpimenta@google.com>2017-07-18 12:55:45 -0700
commit5f46e583b40d86212e7f9c77492768c071a2aa7c (patch)
tree70f41dfdfa589c6fadc063a7c60504656f206823 /android/PhoneNumberUtilsTest.cpp
parent83ebca9ec9c24d0c291e76aa2ef853ad38ea9dfe (diff)
Fix false positives comparing local and intl numbers
Previously when comparing local phone numbers with international it was possible to match the wrong number because the first digit of the area code was being treated as a skippable trunk digit, e.g: "550-123-4567" would be considered equal to "+14501234567". Since there are two different algorithms (loose/old and strict) there are two solutions with the same basic goal: Only ignore mismatches if there's an actual extra digit which could possibly be the trunk digit, i.e: "0550-123-4567" is acceptable as equal to "+15501234567". NB: The US not having a trunk digit to begin with is a different issue entirely - the code is agnostic on which country has which trunk digits! For "loose" matching we achieve this by checking the length of the mismatch. For "strict" matching we keep track of the supposed trunk digit and compare it against the current position in match. So for the above example 5 != 4. Several new unit tests were added (including replicating tests for OldPhoneNumberUtils). I broke down the c++ tests into smaller methods for additional readability. NB: By adding more tests I uncovered that two digit trunk prefixes were never handled correctly for the "strict" matching case. "Loose" matching is much more robust. I commented out the "strict" test cases. Test: All unit tests pass for PhoneNumberUtilsTest, OldPhoneNumberUtilsTest and DatabaseGeneralTest. Bug: 63179537 Bug: 63178542 Bug: 62916088 Change-Id: Idc2a1c2c2f64ed29995208503de4755c521e1c82
Diffstat (limited to 'android/PhoneNumberUtilsTest.cpp')
-rw-r--r--android/PhoneNumberUtilsTest.cpp103
1 files changed, 85 insertions, 18 deletions
diff --git a/android/PhoneNumberUtilsTest.cpp b/android/PhoneNumberUtilsTest.cpp
index beb9c82..ce90c0a 100644
--- a/android/PhoneNumberUtilsTest.cpp
+++ b/android/PhoneNumberUtilsTest.cpp
@@ -32,25 +32,33 @@
using namespace android;
-TEST(PhoneNumberUtils, phone_number_compare_strict) {
+
+TEST(PhoneNumberUtils, compareStrictNullOrEmpty) {
EXPECT_TRUE(phone_number_compare_strict(NULL, NULL));
EXPECT_TRUE(phone_number_compare_strict("", NULL));
EXPECT_TRUE(phone_number_compare_strict(NULL, ""));
EXPECT_TRUE(phone_number_compare_strict("", ""));
+}
+TEST(PhoneNumberUtils, compareStrictDigitsSame) {
EXPECT_TRUE(phone_number_compare_strict("999", "999"));
EXPECT_TRUE(phone_number_compare_strict("119", "119"));
+}
+TEST(PhoneNumberUtils, compareStrictDigitsDifferent) {
EXPECT_FALSE(phone_number_compare_strict("123456789", "923456789"));
EXPECT_FALSE(phone_number_compare_strict("123456789", "123456781"));
EXPECT_FALSE(phone_number_compare_strict("123456789", "1234567890"));
EXPECT_FALSE(phone_number_compare_strict("123456789", "0123456789"));
+}
- // Google, Inc.
+TEST(PhoneNumberUtils, compareStrictGoogle) {
EXPECT_TRUE(phone_number_compare_strict("650-253-0000", "6502530000"));
EXPECT_TRUE(phone_number_compare_strict("650-253-0000", "650 253 0000"));
EXPECT_TRUE(phone_number_compare_strict("650 253 0000", "6502530000"));
+}
+TEST(PhoneNumberUtils, compareStrictTrunkPrefixUs) {
// trunk (NDD) prefix must be properly handled in US
EXPECT_TRUE(phone_number_compare_strict("650-253-0000", "1-650-253-0000"));
EXPECT_TRUE(phone_number_compare_strict("650-253-0000", " 1-650-253-0000"));
@@ -61,70 +69,129 @@ TEST(PhoneNumberUtils, phone_number_compare_strict) {
EXPECT_TRUE(phone_number_compare_strict("+1 650-253-0000", "6502530000"));
EXPECT_TRUE(phone_number_compare_strict("001 650-253-0000", "6502530000"));
EXPECT_TRUE(phone_number_compare_strict("0111 650-253-0000", "6502530000"));
+}
- // Country code is different.
+TEST(PhoneNumberUtils, compareStrictDifferentCountryCode) {
EXPECT_FALSE(phone_number_compare_strict("+19012345678", "+819012345678"));
+}
+
+TEST(PhoneNumberUtils, compareStrictTrunkJapan) {
+ EXPECT_TRUE(phone_number_compare_strict("+31771234567", "0771234567"));
+ EXPECT_TRUE(phone_number_compare_strict("090-1234-5678", "+819012345678"));
+ EXPECT_TRUE(phone_number_compare_strict("090(1234)5678", "+819012345678"));
+ EXPECT_TRUE(phone_number_compare_strict("090-1234-5678", "+81-90-1234-5678"));
- // Russian trunk digit
+ EXPECT_TRUE(phone_number_compare_strict("+819012345678", "090-1234-5678"));
+ EXPECT_TRUE(phone_number_compare_strict("+819012345678", "090(1234)5678"));
+ EXPECT_TRUE(phone_number_compare_strict("+81-90-1234-5678", "090-1234-5678"));
+}
+
+TEST(PhoneNumberUtils, compareStrictTrunkRussia) {
EXPECT_TRUE(phone_number_compare_strict("+79161234567", "89161234567"));
+}
- // French trunk digit
+TEST(PhoneNumberUtils, compareStrictTrunkFrance) {
EXPECT_TRUE(phone_number_compare_strict("+33123456789", "0123456789"));
+}
- // Trunk digit for city codes in the Netherlands
+TEST(PhoneNumberUtils, compareStrictTrunkNetherlandsCities) {
EXPECT_TRUE(phone_number_compare_strict("+31771234567", "0771234567"));
+}
- // Japanese dial
- EXPECT_TRUE(phone_number_compare_strict("090-1234-5678", "+819012345678"));
- EXPECT_TRUE(phone_number_compare_strict("090(1234)5678", "+819012345678"));
- EXPECT_TRUE(phone_number_compare_strict("090-1234-5678", "+81-90-1234-5678"));
+// TODO: Two digit trunk prefixes are not handled
+//TEST(PhoneNumberUtils, compareStrictTrunkHungary) {
+// EXPECT_TRUE(phone_number_compare_strict("+36 1 234 5678", "06 1234-5678"));
+//}
+// TODO: Two digit trunk prefixes are not handled
+//TEST(PhoneNumberUtils, compareStrictTrunkMexico) {
+// EXPECT_TRUE(phone_number_compare_strict("+52 55 1234 5678", "01 55 1234 5678"));
+//}
+
+// TODO: Two digit trunk prefixes are not handled
+//TEST(PhoneNumberUtils, compareStrictTrunkMongolia) {
+// EXPECT_TRUE(phone_number_compare_strict("+976 1 123 4567", "01 1 23 4567"));
+// EXPECT_TRUE(phone_number_compare_strict("+976 2 234 5678", "02 2 34 5678"));
+//}
+
+TEST(PhoneNumberUtils, compareStrictTrunkIgnoreJapan) {
// Trunk prefix must not be ignored in Japan
EXPECT_FALSE(phone_number_compare_strict("090-1234-5678", "90-1234-5678"));
-
EXPECT_FALSE(phone_number_compare_strict("090-1234-5678", "080-1234-5678"));
EXPECT_FALSE(phone_number_compare_strict("090-1234-5678", "190-1234-5678"));
EXPECT_FALSE(phone_number_compare_strict("090-1234-5678", "890-1234-5678"));
+ EXPECT_FALSE(phone_number_compare_strict("080-1234-5678", "+819012345678"));
EXPECT_FALSE(phone_number_compare_strict("+81-90-1234-5678", "+81-090-1234-5678"));
+}
+TEST(PhoneNumberUtils, compareStrictInternationalNational) {
EXPECT_TRUE(phone_number_compare_strict("+593(800)123-1234", "8001231234"));
+}
- // Two continuous 0 at the beginieng of the phone string should not be
+TEST(PhoneNumberUtils, compareStrictTwoContinuousZeros) {
+ // Two continuous 0 at the begining of the phone string should not be
// treated as trunk prefix.
EXPECT_FALSE(phone_number_compare_strict("008001231234", "8001231234"));
+}
+TEST(PhoneNumberUtils, compareStrictCallerIdThailandUs) {
// Test broken caller ID seen on call from Thailand to the US
EXPECT_TRUE(phone_number_compare_strict("+66811234567", "166811234567"));
-
// Confirm that the bug found before does not re-appear.
EXPECT_FALSE(phone_number_compare_strict("080-1234-5678", "+819012345678"));
EXPECT_TRUE(phone_number_compare_strict("650-000-3456", "16500003456"));
EXPECT_TRUE(phone_number_compare_strict("011 1 7005554141", "+17005554141"));
EXPECT_FALSE(phone_number_compare_strict("011 11 7005554141", "+17005554141"));
EXPECT_FALSE(phone_number_compare_strict("+44 207 792 3490", "00 207 792 3490"));
+}
+
+TEST(PhoneNumberUtils, compareStrictNamp1661) {
// This is not related to Thailand case. NAMP "1" + region code "661".
EXPECT_TRUE(phone_number_compare_strict("16610001234", "6610001234"));
+}
+TEST(PhoneNumberUtils, compareStrictAlphaDifferent) {
// We also need to compare two alpha addresses to make sure two different strings
// aren't treated as the same addresses. This is relevant to SMS as SMS sender may
// contain all alpha chars.
EXPECT_FALSE(phone_number_compare_strict("abcd", "bcde"));
+}
+TEST(PhoneNumberUtils, compareStrictAlphaNumericSame) {
// in the U.S. people often use alpha in the phone number to easily remember it
// (e.g. 800-flowers would be dialed as 800-356-9377). Since we accept this form of
// phone number in Contacts and others, we should make sure the comparison method
// handle them.
EXPECT_TRUE(phone_number_compare_strict("1-800-flowers", "800-flowers"));
+}
- // TODO: we currently do not support this comparison. It maybe nice to support this
- // TODO: in the future.
- // EXPECT_TRUE("1-800-flowers", "1-800-356-9377")
-
+TEST(PhoneNumberUtils, compareStrictAlphaNumericDifferent) {
EXPECT_FALSE(phone_number_compare_strict("1-800-flowers", "1-800-abcdefg"));
+}
+// TODO: we currently do not support this comparison.
+// TODO: It maybe be nice to support this in the future.
+//TEST(PhoneNumberUtils, compareStrictLettersToDigits) {
+// EXPECT_TRUE("1-800-flowers", "1-800-356-9377")
+//}
+
+TEST(PhoneNumberUtils, compareStrictWrongPrefix) {
// Currently we cannot get this test through (Japanese trunk prefix is 0,
// but there is no sensible way to know it now (as of 2009-6-12)...
- // EXPECT_FALSE("290-1234-5678", "+819012345678");
+ // EXPECT_FALSE(phone_number_compare_strict("290-1234-5678", "+819012345678"));
+ // EXPECT_FALSE(phone_number_compare_strict("+819012345678", "290-1234-5678"));
+
+ // USA
+ EXPECT_FALSE(phone_number_compare_strict("550-450-3605", "+14504503605"));
+
+ EXPECT_FALSE(phone_number_compare_strict("550-450-3605", "+15404503605"));
+ EXPECT_FALSE(phone_number_compare_strict("550-450-3605", "+15514503605"));
+ EXPECT_FALSE(phone_number_compare_strict("5504503605", "+14504503605"));
+
+ EXPECT_FALSE(phone_number_compare_strict("+14504503605", "550-450-3605"));
+ EXPECT_FALSE(phone_number_compare_strict("+15404503605", "550-450-3605"));
+ EXPECT_FALSE(phone_number_compare_strict("+15514503605", "550-450-3605"));
+ EXPECT_FALSE(phone_number_compare_strict("+14504503605", "5504503605"));
}
TEST(PhoneNumberUtils, phone_number_stripped_reversed_inter) {