mirror of
https://github.com/Respect/Validation.git
synced 2024-05-29 11:52:34 +02:00
Apply contribution guidelines to "FloatVal" rule
Co-Authored-By: Henrique Moody <henriquemoody@gmail.com>
This commit is contained in:
parent
b29bdbd111
commit
c422dc39e4
|
@ -2,7 +2,7 @@
|
|||
|
||||
- `FloatVal()`
|
||||
|
||||
Validates a floating point number.
|
||||
Validate whether the input value is float.
|
||||
|
||||
```php
|
||||
v::floatVal()->validate(1.5); // true
|
||||
|
|
|
@ -13,8 +13,16 @@ declare(strict_types=1);
|
|||
|
||||
namespace Respect\Validation\Exceptions;
|
||||
|
||||
class FloatValException extends ValidationException
|
||||
/**
|
||||
* @author Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
|
||||
* @author Danilo Benevides <danilobenevides01@gmail.com>
|
||||
* @author Henrique Moody <henriquemoody@gmail.com>
|
||||
*/
|
||||
final class FloatValException extends ValidationException
|
||||
{
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public static $defaultTemplates = [
|
||||
self::MODE_DEFAULT => [
|
||||
self::STANDARD => '{{name}} must be a float number',
|
||||
|
|
|
@ -13,8 +13,22 @@ declare(strict_types=1);
|
|||
|
||||
namespace Respect\Validation\Rules;
|
||||
|
||||
class FloatVal extends AbstractRule
|
||||
use function filter_var;
|
||||
use function is_float;
|
||||
|
||||
/**
|
||||
* Validate whether the input value is float.
|
||||
*
|
||||
* @author Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
|
||||
* @author Danilo Benevides <danilobenevides01@gmail.com>
|
||||
* @author Henrique Moody <henriquemoody@gmail.com>
|
||||
* @author Jayson Reis <santosdosreis@gmail.com>
|
||||
*/
|
||||
final class FloatVal extends AbstractRule
|
||||
{
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function validate($input): bool
|
||||
{
|
||||
return is_float(filter_var($input, FILTER_VALIDATE_FLOAT));
|
||||
|
|
38
tests/integration/rules/floatval.phpt
Normal file
38
tests/integration/rules/floatval.phpt
Normal file
|
@ -0,0 +1,38 @@
|
|||
--FILE--
|
||||
<?php
|
||||
require 'vendor/autoload.php';
|
||||
|
||||
use Respect\Validation\Exceptions\FloatValException;
|
||||
use Respect\Validation\Exceptions\NestedValidationException;
|
||||
use Respect\Validation\Validator as v;
|
||||
|
||||
try {
|
||||
v::floatVal()->check('a');
|
||||
} catch (FloatValException $exception) {
|
||||
echo $exception->getMessage().PHP_EOL;
|
||||
}
|
||||
|
||||
try {
|
||||
v::not(v::floatVal())->check(165.0);
|
||||
} catch (FloatValException $exception) {
|
||||
echo $exception->getMessage().PHP_EOL;
|
||||
}
|
||||
|
||||
try {
|
||||
v::floatVal()->assert('a');
|
||||
} catch (NestedValidationException $exception) {
|
||||
echo $exception->getFullMessage().PHP_EOL;
|
||||
}
|
||||
|
||||
try {
|
||||
v::not(v::floatVal())->assert('165.7');
|
||||
} catch (NestedValidationException $exception) {
|
||||
echo $exception->getFullMessage().PHP_EOL;
|
||||
}
|
||||
|
||||
?>
|
||||
--EXPECTF--
|
||||
"a" must be a float number
|
||||
165.0 must not be a float number
|
||||
- "a" must be a float number
|
||||
- "165.7" must not be a float number
|
|
@ -13,65 +13,53 @@ declare(strict_types=1);
|
|||
|
||||
namespace Respect\Validation\Rules;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Respect\Validation\Test\RuleTestCase;
|
||||
|
||||
/**
|
||||
* @group rule
|
||||
* @group rule
|
||||
*
|
||||
* @covers \Respect\Validation\Rules\FloatVal
|
||||
* @covers \Respect\Validation\Exceptions\FloatValException
|
||||
*
|
||||
* @author Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
|
||||
* @author Danilo Benevides <danilobenevides01@gmail.com>
|
||||
* @author Gabriel Caruso <carusogabriel34@gmail.com>
|
||||
* @author Henrique Moody <henriquemoody@gmail.com>
|
||||
*/
|
||||
class FloatValTest extends TestCase
|
||||
final class FloatValTest extends RuleTestCase
|
||||
{
|
||||
protected $floatValidator;
|
||||
|
||||
protected function setUp(): void
|
||||
/*
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function providerForValidInput(): array
|
||||
{
|
||||
$this->floatValidator = new FloatVal();
|
||||
}
|
||||
$rule = new FloatVal();
|
||||
|
||||
/**
|
||||
* @dataProvider providerForFloat
|
||||
*/
|
||||
public function testFloatNumbersShouldPass($input): void
|
||||
{
|
||||
$this->floatValidator->assert($input);
|
||||
self::assertTrue($this->floatValidator->__invoke($input));
|
||||
$this->floatValidator->check($input);
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider providerForNotFloat
|
||||
* @expectedException \Respect\Validation\Exceptions\FloatValException
|
||||
*/
|
||||
public function testNotFloatNumbersShouldFail($input): void
|
||||
{
|
||||
self::assertFalse($this->floatValidator->__invoke($input));
|
||||
$this->floatValidator->assert($input);
|
||||
}
|
||||
|
||||
public function providerForFloat()
|
||||
{
|
||||
return [
|
||||
[165],
|
||||
[1],
|
||||
[0],
|
||||
[0.0],
|
||||
['1'],
|
||||
['19347e12'],
|
||||
[165.0],
|
||||
['165.7'],
|
||||
[1e12],
|
||||
[$rule, 165],
|
||||
[$rule, 1],
|
||||
[$rule, 0],
|
||||
[$rule, 0.0],
|
||||
[$rule, '1'],
|
||||
[$rule, '19347e12'],
|
||||
[$rule, 165.0],
|
||||
[$rule, '165.7'],
|
||||
[$rule, 1e12],
|
||||
];
|
||||
}
|
||||
|
||||
public function providerForNotFloat()
|
||||
/*
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function providerForInvalidInput(): array
|
||||
{
|
||||
$rule = new FloatVal();
|
||||
|
||||
return [
|
||||
[''],
|
||||
[null],
|
||||
['a'],
|
||||
[' '],
|
||||
['Foo'],
|
||||
[$rule, ''],
|
||||
[$rule, null],
|
||||
[$rule, 'a'],
|
||||
[$rule, ' '],
|
||||
[$rule, 'Foo'],
|
||||
];
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue