mirror of
https://github.com/Respect/Validation.git
synced 2026-03-16 07:15:45 +01:00
Due to the current status of the development of the library, it seems like we will be supporting version 1.1 for a long time. Even when we release version 2.0 we will still give support for version 1.1 for a while. This commit will make sure that version 1.1 is fully supported for PHP 7.2 and 7.3. Also, it will remove the support for HHVM since it will not keep the compatibility with PHP anymore [1]. In order to make that happen, this commit will create a TestCase from Validation so we can use the same API to create mocks in both PHPUnit versions 4.0 and 5.0. During the development of this commit, I noticed that PHPUnit 4.0 had issues to mock "SplFileInfo" and for that reason, this commit will also replace those mocks by "SplFileInfo" instances. [1]: https://hhvm.com/blog/2018/09/12/end-of-php-support-future-of-hack.html Signed-off-by: Henrique Moody <henriquemoody@gmail.com>
71 lines
1.8 KiB
PHP
71 lines
1.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\RuleTestCase;
|
|
use function mb_convert_encoding;
|
|
|
|
/**
|
|
* @group rule
|
|
*
|
|
* @covers \Respect\Validation\Rules\Charset
|
|
*
|
|
* @author Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
|
|
* @author Gabriel Caruso <carusogabriel34@gmail.com>
|
|
* @author Henrique Moody <henriquemoody@gmail.com>
|
|
* @author William Espindola <oi@williamespindola.com.br>
|
|
*/
|
|
final class CharsetTest extends RuleTestCase
|
|
{
|
|
/**
|
|
* @test
|
|
*
|
|
* @expectedException \Respect\Validation\Exceptions\ComponentException
|
|
* @expectedExceptionMessage Invalid charset
|
|
*/
|
|
public function itShouldThrowsExceptionWhenCharsetIsNotValid(): void
|
|
{
|
|
new Charset('UTF-8', 'UTF-9');
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function providerForValidInput(): array
|
|
{
|
|
return [
|
|
[new Charset('UTF-8'), ''],
|
|
[new Charset('ISO-8859-1'), mb_convert_encoding('açaí', 'ISO-8859-1')],
|
|
[new Charset('UTF-8', 'ASCII'), 'strawberry'],
|
|
[new Charset('ASCII'), mb_convert_encoding('strawberry', 'ASCII')],
|
|
[new Charset('UTF-8'), '日本国'],
|
|
[new Charset('ISO-8859-1', 'EUC-JP'), '日本国'],
|
|
[new Charset('UTF-8'), 'açaí'],
|
|
[new Charset('ISO-8859-1'), 'açaí'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function providerForInvalidInput(): array
|
|
{
|
|
$rule = new Charset('ASCII');
|
|
|
|
return [
|
|
[$rule, '日本国'],
|
|
[$rule, 'açaí'],
|
|
];
|
|
}
|
|
}
|