mirror of
https://github.com/Respect/Validation.git
synced 2026-03-16 23:35:45 +01:00
This validator is made to validate numbers in any base, even with custom bases
It also have a shortcut, you can use something like
v::base3()->assert('0212');
instead of
v::base(3)->assert('0212');
You can also use custom numeric sequences, like
v::base(3, 'xy')->assert('xyxyx');
129 lines
No EOL
3.1 KiB
PHP
129 lines
No EOL
3.1 KiB
PHP
<?php
|
|
|
|
namespace Respect\Validation\Rules;
|
|
|
|
use \Respect\Validation\Validator as v;
|
|
|
|
class BaseTest extends \PHPUnit_Framework_TestCase
|
|
{
|
|
|
|
protected $object;
|
|
|
|
protected function setUp()
|
|
{
|
|
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerForBase
|
|
*
|
|
*/
|
|
public function testBase($base, $input)
|
|
{
|
|
$object = new Base($base);
|
|
$this->assertTrue($object->validate($input));
|
|
$this->assertTrue($object->check($input));
|
|
$this->assertTrue($object->assert($input));
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerForBase
|
|
*
|
|
*/
|
|
public function testBaseShortcut($base, $input)
|
|
{
|
|
$method = 'base' . $base;
|
|
$object = v::$method();
|
|
|
|
$this->assertTrue($object->validate($input));
|
|
$this->assertTrue($object->check($input));
|
|
$this->assertTrue($object->assert($input));
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerForInvalidBase
|
|
*
|
|
*/
|
|
public function testInvalidBase($base, $input)
|
|
{
|
|
$object = new Base($base);
|
|
$this->assertFalse($object->validate($input));
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerForInvalidBase
|
|
*
|
|
*/
|
|
public function testInvalidBaseShortcut($base, $input)
|
|
{
|
|
$method = 'base' . $base;
|
|
$object = v::$method();
|
|
$this->assertFalse($object->validate($input));
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerForExceptionBase
|
|
* @expectedException Respect\Validation\Exceptions\BaseException
|
|
*/
|
|
public function testExceptionBase($base, $input)
|
|
{
|
|
$object = new Base($base);
|
|
$this->assertTrue($object->validate($input));
|
|
$this->assertTrue($object->assert($input));
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerForCustomBase
|
|
*
|
|
*/
|
|
public function testCustomBase($base, $custom, $input)
|
|
{
|
|
$object = new Base($base, $custom);
|
|
$this->assertTrue($object->validate($input));
|
|
$this->assertTrue($object->check($input));
|
|
$this->assertTrue($object->assert($input));
|
|
}
|
|
|
|
public function providerForBase()
|
|
{
|
|
return array(
|
|
array(2, '011010001'),
|
|
array(3, '0120122001'),
|
|
array(8, '01234567520'),
|
|
array(16, '012a34f5675c20d'),
|
|
array(20, '012ah34f5675hic20dj'),
|
|
array(50, '012ah34f56A75FGhic20dj'),
|
|
array(62, 'Z01xSsg5675hic20dj')
|
|
);
|
|
}
|
|
|
|
public function providerForInvalidBase()
|
|
{
|
|
return array(
|
|
array(2, '01210103001'),
|
|
array(3, '0120125f2001'),
|
|
array(8, '01234dfZ567520'),
|
|
array(16, '012aXS34f5675c20d'),
|
|
array(20, '012ahZX34f5675hic20dj'),
|
|
array(50, '012ahGZ34f56A75FGhic20dj'),
|
|
array(61, 'Z01xSsg5675hic20dj')
|
|
);
|
|
}
|
|
|
|
public function providerForCustomBase()
|
|
{
|
|
return array(
|
|
array(2, 'xy', 'xyyxyxxy'),
|
|
array(3, 'pfg', 'gfpffp')
|
|
);
|
|
}
|
|
|
|
public function providerForExceptionBase()
|
|
{
|
|
return array(
|
|
array(63, '01210103001'),
|
|
array(125, '0120125f2001')
|
|
);
|
|
}
|
|
|
|
} |