respect-validation/tests/unit/Rules/SubdivisionCodeTest.php
Henrique Moody 718bacad04
Remove subdivision code rules per country
There is no much benefit from having individual rules for each country's
subdivision, quite the opposite. It increases the amount of code and
makes it hard to change the implementation of these rules. Right now,
the only sane way to change those rules is with a customized script.

This commit will remove the Subdivision Code rules per country and
instead will put that information into JSON files.

We both wouldn't like to keep this in this library anymore, and we are
considering having another library to deal with this data [1], but since
it seems like it may take some time, looks better to do it temporarily
here.

[1]: https://github.com/sokil/php-isocodes/issues/12

Co-authored-by: Mazen Touati <mazen_touati@hotmail.com>
Signed-off-by: Henrique Moody <henriquemoody@gmail.com>
2019-04-06 23:05:24 +02:00

112 lines
2.8 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.
*/
declare(strict_types=1);
namespace Respect\Validation\Rules;
use Respect\Validation\Test\TestCase;
/**
* @covers \Respect\Validation\Exceptions\SubdivisionCodeException
* @covers \Respect\Validation\Rules\SubdivisionCode
*
* @author Gabriel Caruso <carusogabriel34@gmail.com>
* @author Henrique Moody <henriquemoody@gmail.com>
*/
final class SubdivisionCodeTest extends TestCase
{
/**
* @expectedException \Respect\Validation\Exceptions\ComponentException
* @expectedExceptionMessage "whatever" is not a supported country code
*
* @test
*/
public function shouldThrowsExceptionWhenInvalidFormat(): void
{
new SubdivisionCode('whatever');
}
/**
* @expectedException \Respect\Validation\Exceptions\ComponentException
* @expectedExceptionMessage "JK" is not a supported country code
*
* @test
*/
public function shouldNotAcceptWrongNamesOnConstructor(): void
{
new SubdivisionCode('JK');
}
/**
* @return mixed[][]
*/
public function providerForValidSubdivisionCodeInformation(): array
{
return [
['AQ', null],
['BR', 'SP'],
['MV', '00'],
['US', 'CA'],
['YT', ''],
];
}
/**
* @dataProvider providerForValidSubdivisionCodeInformation
*
* @test
*/
public function shouldValidateValidSubdivisionCodeInformation(string $countryCode, ?string $input): void
{
$countrySubdivision = new SubdivisionCode($countryCode);
self::assertTrue($countrySubdivision->validate($input));
}
/**
* @return mixed[][]
*/
public function providerForInvalidSubdivisionCodeInformation(): array
{
return [
['BR', 'CA'],
['MV', 0],
['US', 'CE'],
];
}
/**
* @dataProvider providerForInvalidSubdivisionCodeInformation
*
* @test
*
* @param mixed $input
*/
public function shouldNotValidateInvalidSubdivisionCodeInformation(string $countryCode, $input): void
{
$countrySubdivision = new SubdivisionCode($countryCode);
self::assertFalse($countrySubdivision->validate($input));
}
/**
* @expectedException \Respect\Validation\Exceptions\SubdivisionCodeException
* @expectedExceptionMessage "CA" must be a subdivision code of "Brazil"
*
* @test
*/
public function shouldThrowsSubdivisionCodeException(): void
{
$countrySubdivision = new SubdivisionCode('BR');
$countrySubdivision->assert('CA');
}
}