验证器.验证 IP 许可

Testing Is Documentation

tests/Validate/Validator/DenyIpTest.php验证器.验证 IP 许可 - 图1

Uses

  1. <?php
  2. use Leevel\Validate\Validator;
  3. use stdClass;

验证通过的数据

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

  1. # Tests\Validate\Validator\DenyIpTest::baseUseProvider
  2. public function baseUseProvider(): array
  3. {
  4. return [
  5. ['8.8.8.10', '8.8.8.8,127.0.0.1'],
  6. ['127.0.5.1', '8.8.8.8,127.0.0.1'],
  7. ];
  8. }

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

  1. public function testBaseUse($value, string $param): void
  2. {
  3. $validate = new Validator(
  4. [
  5. 'name' => $value,
  6. ],
  7. [
  8. 'name' => 'deny_ip:'.$param,
  9. ]
  10. );
  11. $this->assertTrue($validate->success());
  12. }

未验证通过的数据

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

  1. # Tests\Validate\Validator\DenyIpTest::badProvider
  2. public function badProvider(): array
  3. {
  4. return [
  5. ['8.8.8.8', '8.8.8.8,127.0.0.1'],
  6. ['127.0.0.1', '8.8.8.8,127.0.0.1'],
  7. [new stdClass(), '8.8.8.8,127.0.0.1'],
  8. [[1, 2], '8.8.8.8,127.0.0.1'],
  9. [[[], []], '8.8.8.8,127.0.0.1'],
  10. [['foo', 'bar'], '8.8.8.8,127.0.0.1'],
  11. [true, '8.8.8.8,127.0.0.1'],
  12. [false, '8.8.8.8,127.0.0.1'],
  13. ];
  14. }

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

  1. public function testBad($value, string $param): void
  2. {
  3. $validate = new Validator(
  4. [
  5. 'name' => $value,
  6. ],
  7. [
  8. 'name' => 'deny_ip:'.$param,
  9. ]
  10. );
  11. $this->assertFalse($validate->success());
  12. }

deny_ip 参数缺失

  1. public function testMissParam(): void
  2. {
  3. $this->expectException(\InvalidArgumentException::class);
  4. $this->expectExceptionMessage(
  5. 'Missing the first element of param.'
  6. );
  7. $validate = new Validator(
  8. [
  9. 'name' => '',
  10. ],
  11. [
  12. 'name' => 'deny_ip',
  13. ]
  14. );
  15. $validate->success();
  16. }