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

Uses

<?php

use Leevel\Validate\Validator;
use stdClass;

# 验证通过的数据

以下是通过的校验数据示例。

# Tests\Validate\Validator\JsonTest::baseUseProvider
public function baseUseProvider(): array
{
    return [
        ['"abc"'],
        ['{"foo":"bar"}'],
        [new TestJson()],
    ];
}

\Tests\Validate\Validator\TestJson 声明如下

namespace Tests\Validate\Validator;

class TestJson
{
    public function __toString()
    {
        return '{"hello":"world"}';
    }
}

上面的数据是测试的数据提供者。

public function testBaseUse($value): void
{
    $validate = new Validator(
        [
            'name' => $value,
        ],
        [
            'name'     => 'json',
        ]
    );

    $this->assertTrue($validate->success());
}

# 未验证通过的数据

以下是未通过的校验数据示例。

# Tests\Validate\Validator\JsonTest::badProvider
public function badProvider(): array
{
    return [
        ['not numeric'],
        [[]],
        [new stdClass()],
        [['foo', 'bar']],
        [[1, 2]],
        ['Foo'],
        ['hEllo'],
        [null],
    ];
}

上面的数据是测试的数据提供者。

public function testBad($value): void
{
    $validate = new Validator(
        [
            'name' => $value,
        ],
        [
            'name'     => 'json',
        ]
    );

    $this->assertFalse($validate->success());
}