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 mixed $value
|
||||
* @param array $params
|
||||
* @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());
|
||||
}
|
||||
|
||||
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()
|
||||
{
|
||||
$v = new Validator(array('num' => '42.341569'));
|
||||
$v->rule('integer', 'num');
|
||||
$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->rule('integer', 'num');
|
||||
@ -139,14 +153,6 @@ class ValidateTest extends BaseTestCase
|
||||
$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()
|
||||
{
|
||||
$v = new Validator(array('str' => 'happy'));
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user