respect-validation/tests/unit/Rules/PostalCodeTest.php
ong-ar 892b39e5ff
Update Korean postal code validation
The Korea Postal code system changed from a 6-digit postal code system
to a 5-digit postal code system on August 1, 2015 [1] [2].

This commit makes sure that the "PostalCode" rule validates Korean
postal codes correctly.

[1]: http://www.fedex.com/ky/koreapostalcode/index.html
[2]: http://www.epost.go.kr/roadAreaCdEng.retrieveLnEngAreaCdList.comm

Co-authored-by: Henrique Moody <henriquemoody@gmail.com>
2018-10-10 20:51:31 +02:00

138 lines
3.7 KiB
PHP

<?php
/*
* This file is part of Respect/Validation.
*
* (c) Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
*
* For the full copyright and license information, please view the "LICENSE.md"
* file that was distributed with this source code.
*/
namespace Respect\Validation\Rules;
/**
* @group rule
* @covers Respect\Validation\Rules\PostalCode
* @covers Respect\Validation\Exceptions\PostalCodeException
*/
class PostalCodeTest extends \PHPUnit_Framework_TestCase
{
public function testShouldUsePatternAccordingToCountryCode()
{
$countryCode = 'BR';
$rule = new PostalCode($countryCode);
$actualPattern = $rule->regex;
$expectedPattern = $rule->postalCodes[$countryCode];
$this->assertEquals($expectedPattern, $actualPattern);
}
public function testShouldNotBeCaseSensitiveWhenChoosingPatternAccordingToCountryCode()
{
$rule1 = new PostalCode('BR');
$rule2 = new PostalCode('br');
$this->assertEquals($rule1->regex, $rule2->regex);
}
public function testShouldUseDefaultPatternWhenCountryCodeDoesNotHavePostalCode()
{
$rule = new PostalCode('ZW');
$actualPattern = $rule->regex;
$expectedPattern = PostalCode::DEFAULT_PATTERN;
$this->assertEquals($expectedPattern, $actualPattern);
}
public function testShouldValidateEmptyStringsWhenUsingDefaultPattern()
{
$rule = new PostalCode('ZW');
$this->assertTrue($rule->validate(''));
}
public function testShouldNotValidateNonEmptyStringsWhenUsingDefaultPattern()
{
$rule = new PostalCode('ZW');
$this->assertFalse($rule->validate(' '));
}
/**
* @expectedException Respect\Validation\Exceptions\ComponentException
* @expectedExceptionMessage Cannot validate postal code from "Whatever" country
*/
public function testShouldThrowsExceptionWhenCountryCodeIsNotValid()
{
new PostalCode('Whatever');
}
/**
* @dataProvider validPostalCodesProvider
*/
public function testShouldValidatePatternAccordingToTheDefinedCountryCode($countryCode, $postalCode)
{
$rule = new PostalCode($countryCode);
$this->assertTrue($rule->validate($postalCode));
}
public function validPostalCodesProvider()
{
return [
['BR', '02179-000'],
['BR', '02179000'],
['GB', 'GIR 0AA'],
['GB', 'PR1 9LY'],
['US', '02179'],
['YE', ''],
['PL', '99-300'],
['NL', '1012 GX'],
['NL', '1012GX'],
['PT', '3660-606'],
['PT', '3660606'],
['CO', '110231'],
['KR', '03187'],
];
}
/**
* @dataProvider invalidPostalCodesProvider
*/
public function testShouldNotValidatePatternAccordingToTheDefinedCountryCode($countryCode, $postalCode)
{
$rule = new PostalCode($countryCode);
$this->assertFalse($rule->validate($postalCode));
}
/**
* @expectedException Respect\Validation\Exceptions\PostalCodeException
* @expectedExceptionMessage "02179-000" must be a valid postal code on "US"
*/
public function testShouldThrowsPostalCodeExceptionWhenValidationFails()
{
$rule = new PostalCode('US');
$rule->check('02179-000');
}
public function invalidPostalCodesProvider()
{
return [
['BR', '02179'],
['BR', '02179.000'],
['GB', 'GIR 00A'],
['GB', 'GIR0AA'],
['GB', 'PR19LY'],
['US', '021 79'],
['YE', '02179'],
['PL', '99300'],
['KR', '548940'],
['KR', '548-940'],
];
}
}