Skip to content

验证器.验证是否为正常的 JSON 数据

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());
}