验证器.验证是否为正常的 JSON 数据
Testing Is Documentation
Uses
php
<?php
use Leevel\Kernel\Utils\Api;
use Leevel\Validate\Validator;
use PHPUnit\Framework\Attributes\DataProvider;
验证通过的数据
以下是通过的校验数据示例。
php
# Tests\Validate\Validator\JsonTest::baseUseProvider
public static function baseUseProvider(): array
{
return [
['"abc"'],
['{"foo":"bar"}'],
[new TestJson()],
];
}
\Tests\Validate\Validator\TestJson
声明如下
php
namespace Tests\Validate\Validator;
class TestJson
{
public function __toString()
{
return '{"hello":"world"}';
}
}
上面的数据是测试的数据提供者。
php
public function testBaseUse($value): void
{
$validate = new Validator(
[
'name' => $value,
],
[
'name' => 'json',
]
);
self::assertTrue($validate->success());
}
未验证通过的数据
以下是未通过的校验数据示例。
php
# Tests\Validate\Validator\JsonTest::badProvider
public static function badProvider(): array
{
return [
['not numeric'],
[[]],
[new \stdClass()],
[['foo', 'bar']],
[[1, 2]],
['Foo'],
['hEllo'],
[null],
[TestJson2::class],
];
}
\Tests\Validate\Validator\TestJson2
声明如下
php
namespace Tests\Validate\Validator;
class TestJson2 {}
上面的数据是测试的数据提供者。
php
public function testBad($value): void
{
$validate = new Validator(
[
'name' => $value,
],
[
'name' => 'json',
]
);
self::assertFalse($validate->success());
}