验证器.是否为正确的时区
Testing Is Documentation
Uses
php
<?php
use Leevel\Kernel\Utils\Api;
use Leevel\Validate\Validator;
use PHPUnit\Framework\Attributes\DataProvider;
验证通过的数据
以下是通过的校验数据示例。
php
# Tests\Validate\Validator\TimezoneTest::baseUseProvider
public static function baseUseProvider(): array
{
return [
['-0400'],
['EDT'],
['Asia/Shanghai'], // 上海
['Asia/Hong_Kong'], // 香港
['Asia/Chongqing'], // 重庆
['Asia/Urumqi'], // 乌鲁木齐
['Asia/Macao'], // 澳门
['Asia/Taipei'], // 台北
['Asia/Singapore'], // 新加坡
['PRC'], // 设置中国时区
['Etc/GMT'], // 格林威治标准时间
];
}
上面的数据是测试的数据提供者。
php
public function testBaseUse($value): void
{
$validate = new Validator(
[
'name' => $value,
],
[
'name' => 'timezone',
]
);
self::assertTrue($validate->success());
}
未验证通过的数据
以下是未通过的校验数据示例。
php
# Tests\Validate\Validator\TimezoneTest::badProvider
public static function badProvider(): array
{
return [
['Asia/foo'],
['Asia/bar'],
['foo'],
['bar'],
['2018'],
['2018-44-22'],
['2018-12-42'],
[''],
[[1, 2]],
];
}
上面的数据是测试的数据提供者。
php
public function testBad($value): void
{
$validate = new Validator(
[
'name' => $value,
],
[
'name' => 'timezone',
]
);
self::assertFalse($validate->success());
}