respect-validation/tests/unit/Rules/NumericValTest.php
Henrique Moody c80524b457
Method assert() should not have a return value
One this method should throw an exception when the input is not valid,
returning `TRUE` when it succeeds is not really consistent.
2018-01-28 17:38:40 +01:00

74 lines
1.5 KiB
PHP

<?php
/*
* This file is part of Respect/Validation.
*
* (c) Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
*
* For the full copyright and license information, please view the "LICENSE.md"
* file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Respect\Validation\Rules;
use PHPUnit\Framework\TestCase;
/**
* @group rule
* @covers \Respect\Validation\Rules\NumericVal
* @covers \Respect\Validation\Exceptions\NumericValException
*/
class NumericValTest extends TestCase
{
protected $object;
protected function setUp(): void
{
$this->object = new NumericVal();
}
/**
* @dataProvider providerForNumeric
*/
public function testNumeric($input): void
{
self::assertTrue($this->object->__invoke($input));
$this->object->check($input);
$this->object->assert($input);
}
/**
* @dataProvider providerForNotNumeric
* @expectedException \Respect\Validation\Exceptions\NumericValException
*/
public function testNotNumeric($input): void
{
self::assertFalse($this->object->__invoke($input));
$this->object->assert($input);
}
public function providerForNumeric()
{
return [
[165],
[165.0],
[-165],
['165'],
['165.0'],
['+165.0'],
];
}
public function providerForNotNumeric()
{
return [
[''],
[null],
['a'],
[' '],
['Foo'],
];
}
}