Skip to content
This repository has been archived by the owner on Jan 31, 2020. It is now read-only.

Commit

Permalink
Merge pull request zendframework/zendframework#4940 from qapa/zend-va…
Browse files Browse the repository at this point in the history
…lidator-bitwise

New Zend\Validator\Bitwise
  • Loading branch information
weierophinney committed Oct 22, 2013
149 parents d1facdb + 1b49389 + d7193b9 + 3fed016 + 082acdb + 3ddc8fa + 274bd7f + c9e433d + 99f6515 + 8d1a271 + 2c2bc35 + 16359e3 + 10b9b3c + d05ac01 + 9628c66 + 66c8763 + 943d333 + 8342f70 + 4eb4184 + 4ea0bc2 + 860b725 + 7d29287 + 49a7844 + 3836aa0 + de1fe83 + 929eb12 + 6e6902f + f823467 + f3b3f76 + 93aff47 + 5f2adec + 7674ec8 + 2200ed2 + f033c86 + d43a2da + 4434323 + 88b21e1 + b02b602 + b692de7 + 7f833d2 + 2eaf4da + a7848de + 5bd9f85 + d7a26e8 + 173f53d + bd77e8e + 45f017e + 118612c + 3a09f79 + 47d92bc + dbf56ad + a753b61 + 6467186 + 5ac4124 + 2bf68ca + e7cd709 + 7a552db + f112e0c + cec42fc + 066eb37 + 3569d8b + 00def10 + ecae47b + 0e552a5 + 4f854c2 + 2b17650 + c1c0447 + 73b1f80 + dd4a335 + a40eb42 + 9262db1 + bdbd950 + 6d50117 + 10b08a7 + f692a0d + ebe63d3 + 528260b + 5f04a7f + c0dcd12 + 224f280 + 8785f25 + 866539b + d711927 + e280213 + 002f0d4 + 5ffcbbe + 8937705 + 5803840 + 3d7cd9a + 6b14f0e + 24bd169 + 0eba870 + 4e4acfe + 9e243bd + e156354 + 2a84563 + 3f1f758 + 4e425f4 + 7030f97 + ea08a0f + 213ebd9 + 5d80740 + 800c29c + be31ff1 + 8f989d6 + 8b02a8b + 4cfd82c + c411f06 + 4229561 + b321e3b + 2e660f9 + 3fff65f + a2eb7bf + 82469ff + 22fa741 + 99819cb + 8c16404 + a7c0820 + 7d277af + da0bec5 + 33f214a + a07f208 + 963d2fe + 1100f88 + 6713bf5 + 7421758 + b64a638 + 772a2a1 + dff3231 + 56bc4ca + 463e3d7 + 14bd316 + f8b9e58 + ef0268c + 3fe91ce + 130da19 + 6d4097d + 02fa5b3 + 927b7df + 2fbc2a0 + c772270 + 1cdc0cc + ecb5260 + 23824d1 + 56e8233 + 3c0e07f + 8fb917d + 575c951 + 4d5e3d3 commit 392817d
Show file tree
Hide file tree
Showing 2 changed files with 373 additions and 0 deletions.
192 changes: 192 additions & 0 deletions src/Bitwise.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,192 @@
<?php
/**
* Zend Framework (http://framework.zend.com/)
*
* @link http://github.com/zendframework/zf2 for the canonical source repository
* @copyright Copyright (c) 2005-2013 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

namespace Zend\Validator;

use Traversable;

class Bitwise extends AbstractValidator
{
const OP_AND = 'and';
const OP_XOR = 'xor';

const NOT_AND = 'notAnd';
const NOT_AND_STRICT = 'notAndStrict';
const NOT_XOR = 'notXor';

/**
* @var integer
*/
protected $control;

/**
* Validation failure message template definitions
*
* @var array
*/
protected $messageTemplates = array(
self::NOT_AND => "The input has no common bit set with '%control%'",
self::NOT_AND_STRICT => "The input doesn't have the same bits set as '%control%'",
self::NOT_XOR => "The input has common bit set with '%control%'",
);

/**
* Additional variables available for validation failure messages
*
* @var array
*/
protected $messageVariables = array(
'control' => 'control',
);

/**
* @var integer
*/
protected $operator;

/**
* @var boolean
*/
protected $strict = false;

/**
* Sets validator options
* Accepts the following option keys:
* 'control' => integer
* 'operator' =>
* 'strict' => boolean
*
* @param array|Traversable $options
*/
public function __construct($options = null)
{
if ($options instanceof Traversable) {
$options = iterator_to_array($options);
}

if (!is_array($options)) {
$options = func_get_args();

$temp['control'] = array_shift($options);

if (!empty($options)) {
$temp['operator'] = array_shift($options);
}

if (!empty($options)) {
$temp['strict'] = array_shift($options);
}

$options = $temp;
}

parent::__construct($options);
}

/**
* Returns the control parameter.
*
* @return integer
*/
public function getControl()
{
return $this->control;
}

/**
* Returns the operator parameter.
*
* @return string
*/
public function getOperator()
{
return $this->operator;
}

/**
* Returns the strict parameter.
*
* @return boolean
*/
public function getStrict()
{
return $this->strict;
}

/**
* Returns true if and only if $value is between min and max options, inclusively
* if inclusive option is true.
*
* @param mixed $value
* @return bool
*/
public function isValid($value)
{
$this->setValue($value);

if (self::OP_AND === $this->operator) {
if ($this->strict) {
// All the bits set in value must be set in control
$this->error(self::NOT_AND_STRICT);

return (bool) (($this->control & $value) == $value);
} else {
// At least one of the bits must be common between value and control
$this->error(self::NOT_AND);

return (bool) ($this->control & $value);
}
} elseif (self::OP_XOR === $this->operator) {
$this->error(self::NOT_XOR);

return (bool) (($this->control ^ $value) === ($this->control | $value));
}

return false;
}

/**
* Sets the control parameter.
*
* @param integer $control
* @return Bitwise
*/
public function setControl($control)
{
$this->control = (int) $control;

return $this;
}

/**
* Sets the operator parameter.
*
* @param string $operator
* @return Bitwise
*/
public function setOperator($operator)
{
$this->operator = $operator;

return $this;
}

/**
* Sets the strict parameter.
*
* @param boolean $strict
* @return Bitwise
*/
public function setStrict($strict)
{
$this->strict = (bool) $strict;

return $this;
}
}
181 changes: 181 additions & 0 deletions test/BitwiseTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,181 @@
<?php
/**
* Zend Framework (http://framework.zend.com/)
*
* @link http://github.com/zendframework/zf2 for the canonical source repository
* @copyright Copyright (c) 2005-2013 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/

namespace ZendTest\Validator;

use Zend\Validator\Bitwise;

class BitwiseTest extends \PHPUnit_Framework_TestCase
{
/**
* @var \Zend\Validator\Bitwise
*/
public $validator;

public function setUp()
{
$this->validator = new Bitwise();
}

/**
* @covers \Zend\Validator\Bitwise::__construct()
* @dataProvider constructDataProvider
*
* @param array $args
* @param array $options
*/
public function testConstruct(array $args, array $options)
{
$validator = new Bitwise($args);

$this->assertSame($options['control'], $validator->getControl());
$this->assertSame($options['operator'], $validator->getOperator());
$this->assertSame($options['strict'], $validator->getStrict());
}

public function constructDataProvider()
{
return array(
array(
array(),
array('control' => null, 'operator' => null, 'strict' => false),
),
array(
array('control' => 0x1),
array('control' => 0x1, 'operator' => null, 'strict' => false),
),
array(
array('control' => 0x1, 'operator' => Bitwise::OP_AND),
array('control' => 0x1, 'operator' => Bitwise::OP_AND, 'strict' => false),
),
array(
array('control' => 0x1, 'operator' => Bitwise::OP_AND, 'strict' => true),
array('control' => 0x1, 'operator' => Bitwise::OP_AND, 'strict' => true),
),
);

}

/**
* @covers \Zend\Validator\Bitwise::isvalid()
*/
public function testBitwiseAndNotStrict()
{
$controlSum = 0x7; // (0x1 | 0x2 | 0x4) === 0x7

$validator = new Bitwise();
$validator->setControl($controlSum);
$validator->setOperator(Bitwise::OP_AND);

$this->assertTrue($validator->isValid(0x1));
$this->assertTrue($validator->isValid(0x2));
$this->assertTrue($validator->isValid(0x4));
$this->assertFalse($validator->isValid(0x8));

$validator->isValid(0x8);
$messages = $validator->getMessages();
$this->assertArrayHasKey($validator::NOT_AND, $messages);
$this->assertSame("The input has no common bit set with '$controlSum'", $messages[$validator::NOT_AND]);

$this->assertTrue($validator->isValid(0x1 | 0x2));
$this->assertTrue($validator->isValid(0x1 | 0x2 | 0x4));
$this->assertTrue($validator->isValid(0x1 | 0x8));
}

/**
* @covers \Zend\Validator\Bitwise::isvalid()
*/
public function testBitwiseAndStrict()
{
$controlSum = 0x7; // (0x1 | 0x2 | 0x4) === 0x7

$validator = new Bitwise();
$validator->setControl($controlSum);
$validator->setOperator(Bitwise::OP_AND);
$validator->setStrict(true);

$this->assertTrue($validator->isValid(0x1));
$this->assertTrue($validator->isValid(0x2));
$this->assertTrue($validator->isValid(0x4));
$this->assertFalse($validator->isValid(0x8));

$validator->isValid(0x8);
$messages = $validator->getMessages();
$this->assertArrayHasKey($validator::NOT_AND_STRICT, $messages);
$this->assertSame("The input doesn't have the same bits set as '$controlSum'", $messages[$validator::NOT_AND_STRICT]);

$this->assertTrue($validator->isValid(0x1 | 0x2));
$this->assertTrue($validator->isValid(0x1 | 0x2 | 0x4));
$this->assertFalse($validator->isValid(0x1 | 0x8));
}

/**
* @covers \Zend\Validator\Bitwise::isvalid()
*/
public function testBitwiseXor()
{
$controlSum = 0x5; // (0x1 | 0x4) === 0x5

$validator = new Bitwise();
$validator->setControl($controlSum);
$validator->setOperator(Bitwise::OP_XOR);

$this->assertTrue($validator->isValid(0x2));
$this->assertTrue($validator->isValid(0x8));
$this->assertTrue($validator->isValid(0x10));
$this->assertFalse($validator->isValid(0x1));
$this->assertFalse($validator->isValid(0x4));

$validator->isValid(0x4);
$messages = $validator->getMessages();
$this->assertArrayHasKey($validator::NOT_XOR, $messages);
$this->assertSame("The input has common bit set with '$controlSum'", $messages[$validator::NOT_XOR]);

$this->assertTrue($validator->isValid(0x8 | 0x10));
$this->assertFalse($validator->isValid(0x1 | 0x4));
$this->assertFalse($validator->isValid(0x1 | 0x8));
$this->assertFalse($validator->isValid(0x4 | 0x8));
}

/**
* @covers \Zend\Validator\Bitwise::setOperator()
*/
public function testSetOperator()
{
$validator = new Bitwise();

$validator->setOperator(Bitwise::OP_AND);
$this->assertSame(Bitwise::OP_AND, $validator->getOperator());

$validator->setOperator(Bitwise::OP_XOR);
$this->assertSame(Bitwise::OP_XOR, $validator->getOperator());
}

/**
* @covers \Zend\Validator\Bitwise::setStrict()
*/
public function testSetStrict()
{
$validator = new Bitwise();

$this->assertFalse($validator->getStrict(), 'Strict false by default');

$validator->setStrict(false);
$this->assertFalse($validator->getStrict());

$validator->setStrict(true);
$this->assertTrue($validator->getStrict());

$validator = new Bitwise(0x1, Bitwise::OP_AND, false);
$this->assertFalse($validator->getStrict());

$validator = new Bitwise(0x1, Bitwise::OP_AND, true);
$this->assertTrue($validator->getStrict());
}
}

0 comments on commit 392817d

Please sign in to comment.