mirror of
https://github.com/vlucas/valitron.git
synced 2025-12-30 23:01:52 +00:00
Merge pull request #1 from willemwollebrants/feature/fix-interger-validation
Feature/fix interger validation
This commit is contained in:
commit
326d61f186
@ -233,11 +233,17 @@ class Validator
|
|||||||
*
|
*
|
||||||
* @param string $field
|
* @param string $field
|
||||||
* @param mixed $value
|
* @param mixed $value
|
||||||
|
* @param array $params
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
protected function validateInteger($field, $value)
|
protected function validateInteger($field, $value, $params)
|
||||||
{
|
{
|
||||||
return preg_match('/^-?([0-9])+$/i', $value);
|
if (isset($params[0]) && (bool) $params[0]){
|
||||||
|
//strict mode
|
||||||
|
return preg_match('/^-?([0-9])+$/i', $value);
|
||||||
|
}
|
||||||
|
|
||||||
|
return filter_var($value, \FILTER_VALIDATE_INT) !== false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@ -116,19 +116,33 @@ class ValidateTest extends BaseTestCase
|
|||||||
$this->assertTrue($v->validate());
|
$this->assertTrue($v->validate());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testIntegerStrict(){
|
||||||
|
|
||||||
|
$v = new Validator(array('num' => ' 41243'));
|
||||||
|
$v->rule('integer', 'num');
|
||||||
|
$this->assertTrue($v->validate());
|
||||||
|
|
||||||
|
$v = new Validator(array('num' => ' 41243'));
|
||||||
|
$v->rule('integer', 'num', true);
|
||||||
|
$this->assertFalse($v->validate());
|
||||||
|
|
||||||
|
$v = new Validator(array('num' => '+41243'));
|
||||||
|
$v->rule('integer', 'num');
|
||||||
|
$this->assertTrue($v->validate());
|
||||||
|
|
||||||
|
|
||||||
|
$v = new Validator(array('num' => '+41243'));
|
||||||
|
$v->rule('integer', 'num', true);
|
||||||
|
$this->assertFalse($v->validate());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public function testIntegerInvalid()
|
public function testIntegerInvalid()
|
||||||
{
|
{
|
||||||
$v = new Validator(array('num' => '42.341569'));
|
$v = new Validator(array('num' => '42.341569'));
|
||||||
$v->rule('integer', 'num');
|
$v->rule('integer', 'num');
|
||||||
$this->assertFalse($v->validate());
|
$this->assertFalse($v->validate());
|
||||||
|
|
||||||
$v = new Validator(array('num' => ' 41243'));
|
|
||||||
$v->rule('integer', 'num');
|
|
||||||
$this->assertFalse($v->validate());
|
|
||||||
|
|
||||||
$v = new Validator(array('num' => '+1231'));
|
|
||||||
$v->rule('integer', 'num');
|
|
||||||
$this->assertFalse($v->validate());
|
|
||||||
|
|
||||||
$v = new Validator(array('num' => '--1231'));
|
$v = new Validator(array('num' => '--1231'));
|
||||||
$v->rule('integer', 'num');
|
$v->rule('integer', 'num');
|
||||||
@ -139,14 +153,6 @@ class ValidateTest extends BaseTestCase
|
|||||||
$this->assertFalse($v->validate());
|
$this->assertFalse($v->validate());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testIntegerWithMaxValidation()
|
|
||||||
{
|
|
||||||
$v = new Validator(array('num' => ' 4212341569'));
|
|
||||||
$v->rule('integer', 'num');
|
|
||||||
$v->rule('max', 'num', 1000);
|
|
||||||
$this->assertFalse($v->validate());
|
|
||||||
}
|
|
||||||
|
|
||||||
public function testLengthValid()
|
public function testLengthValid()
|
||||||
{
|
{
|
||||||
$v = new Validator(array('str' => 'happy'));
|
$v = new Validator(array('str' => 'happy'));
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user