From 310034309b0b6e22e33bc3c382615cb88c6d9e60 Mon Sep 17 00:00:00 2001 From: George Steel Date: Mon, 1 Jul 2024 17:28:11 +0100 Subject: [PATCH] Ensure `invalidPhoneNumberProvider` does not yield valid numbers This patch prevents potentially valid short numbers from being tested by filtering them out. Recent meta-data changes mean that previously invalid numbers are now possibly valid short numbers. Signed-off-by: George Steel --- composer.lock | 10 +++++----- test/NumberGeneratorTrait.php | 17 ++++++++++++++++- 2 files changed, 21 insertions(+), 6 deletions(-) diff --git a/composer.lock b/composer.lock index 96f9e0f..7586121 100644 --- a/composer.lock +++ b/composer.lock @@ -8,16 +8,16 @@ "packages": [ { "name": "giggsey/libphonenumber-for-php", - "version": "8.13.39", + "version": "8.13.40", "source": { "type": "git", "url": "https://github.com/giggsey/libphonenumber-for-php.git", - "reference": "5a36692616dba1ec4a24217f248021b1ec9cdade" + "reference": "795e0b760e5c439b6fa1ffa787c1d90c2face1ff" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/giggsey/libphonenumber-for-php/zipball/5a36692616dba1ec4a24217f248021b1ec9cdade", - "reference": "5a36692616dba1ec4a24217f248021b1ec9cdade", + "url": "https://api.github.com/repos/giggsey/libphonenumber-for-php/zipball/795e0b760e5c439b6fa1ffa787c1d90c2face1ff", + "reference": "795e0b760e5c439b6fa1ffa787c1d90c2face1ff", "shasum": "" }, "require": { @@ -79,7 +79,7 @@ "issues": "https://github.com/giggsey/libphonenumber-for-php/issues", "source": "https://github.com/giggsey/libphonenumber-for-php" }, - "time": "2024-06-14T12:43:12+00:00" + "time": "2024-07-01T11:38:07+00:00" }, { "name": "giggsey/locale", diff --git a/test/NumberGeneratorTrait.php b/test/NumberGeneratorTrait.php index 27065eb..8c3a343 100644 --- a/test/NumberGeneratorTrait.php +++ b/test/NumberGeneratorTrait.php @@ -98,7 +98,9 @@ public static function validPhoneNumberProvider(): Generator */ public static function invalidPhoneNumberProvider(): Generator { - $util = PhoneNumberUtil::getInstance(); + $util = PhoneNumberUtil::getInstance(); + $shortInfo = ShortNumberInfo::getInstance(); + /** @var list $regions */ $regions = $util->getSupportedRegions(); foreach ($regions as $country) { @@ -106,6 +108,19 @@ public static function invalidPhoneNumberProvider(): Generator if (! $number) { continue; } + + if ( + $util->isValidNumber($number) + || + $util->isValidNumberForRegion($number, $country) + || + $shortInfo->isValidShortNumber($number) + || + $shortInfo->isValidShortNumberForRegion($number, $country) + ) { + continue; + } + $national = $number->getNationalNumber(); assert(is_string($national));