respect-validation/tests/unit/Rules/KeyValueTest.php

115 lines
3.3 KiB
PHP
Raw Normal View History

2015-10-08 18:54:42 +02:00
<?php
/*
* This file is part of Respect/Validation.
*
* (c) Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
*
* For the full copyright and license information, please view the "LICENSE.md"
* file that was distributed with this source code.
*/
namespace Respect\Validation\Rules;
use PHPUnit_Framework_TestCase;
/**
* @group rule
2017-02-04 14:01:14 +01:00
* @covers \Respect\Validation\Rules\KeyValue
* @covers \Respect\Validation\Exceptions\KeyValueException
2015-10-08 18:54:42 +02:00
*/
class KeyValueTest extends PHPUnit_Framework_TestCase
{
public function testShouldDefineValuesOnConstructor()
{
$comparedKey = 'foo';
$ruleName = 'equals';
$baseKey = 'bar';
$rule = new KeyValue($comparedKey, $ruleName, $baseKey);
$this->assertSame($comparedKey, $rule->comparedKey);
$this->assertSame($ruleName, $rule->ruleName);
$this->assertSame($baseKey, $rule->baseKey);
}
public function testShouldNotValidateWhenComparedKeyDoesNotExist()
{
$rule = new KeyValue('foo', 'equals', 'bar');
2015-10-18 03:44:47 +02:00
$this->assertFalse($rule->validate(['bar' => 42]));
2015-10-08 18:54:42 +02:00
}
public function testShouldNotValidateWhenBaseKeyDoesNotExist()
{
$rule = new KeyValue('foo', 'equals', 'bar');
2015-10-18 03:44:47 +02:00
$this->assertFalse($rule->validate(['foo' => true]));
2015-10-08 18:54:42 +02:00
}
public function testShouldNotValidateRuleIsNotValid()
{
$rule = new KeyValue('foo', 'probably_not_a_rule', 'bar');
2015-10-18 03:44:47 +02:00
$this->assertFalse($rule->validate(['foo' => true, 'bar' => false]));
2015-10-08 18:54:42 +02:00
}
public function testShouldValidateWhenDefinedValuesMatch()
{
$rule = new KeyValue('foo', 'equals', 'bar');
2015-10-18 03:44:47 +02:00
$this->assertTrue($rule->validate(['foo' => 42, 'bar' => 42]));
2015-10-08 18:54:42 +02:00
}
public function testShouldValidateWhenDefinedValuesDoesNotMatch()
{
$rule = new KeyValue('foo', 'equals', 'bar');
2015-10-18 03:44:47 +02:00
$this->assertFalse($rule->validate(['foo' => 43, 'bar' => 42]));
2015-10-08 18:54:42 +02:00
}
public function testShouldAssertWhenDefinedValuesMatch()
{
$rule = new KeyValue('foo', 'equals', 'bar');
2015-10-18 03:44:47 +02:00
$this->assertTrue($rule->assert(['foo' => 42, 'bar' => 42]));
2015-10-08 18:54:42 +02:00
}
/**
2017-02-04 14:01:14 +01:00
* @expectedException \Respect\Validation\Exceptions\AllOfException
2015-10-08 18:54:42 +02:00
* @expectedExceptionMessage All of the required rules must pass for foo
*/
public function testShouldAssertWhenDefinedValuesDoesNotMatch()
{
$rule = new KeyValue('foo', 'equals', 'bar');
2015-10-18 03:44:47 +02:00
$rule->assert(['foo' => 43, 'bar' => 42]);
2015-10-08 18:54:42 +02:00
}
/**
2017-02-04 14:01:14 +01:00
* @expectedException \Respect\Validation\Exceptions\KeyValueException
2015-10-08 18:54:42 +02:00
* @expectedExceptionMessage "bar" must be valid to validate "foo"
*/
public function testShouldNotAssertWhenRuleIsNotValid()
{
$rule = new KeyValue('foo', 'probably_not_a_rule', 'bar');
2015-10-18 03:44:47 +02:00
$rule->assert(['foo' => 43, 'bar' => 42]);
2015-10-08 18:54:42 +02:00
}
public function testShouldCheckWhenDefinedValuesMatch()
{
$rule = new KeyValue('foo', 'equals', 'bar');
2015-10-18 03:44:47 +02:00
$this->assertTrue($rule->check(['foo' => 42, 'bar' => 42]));
2015-10-08 18:54:42 +02:00
}
/**
2016-08-26 10:53:29 +02:00
* @expectedException Respect\Validation\Exceptions\EqualsException
* @expectedExceptionMessage foo must equal "bar"
2015-10-08 18:54:42 +02:00
*/
public function testShouldCheckWhenDefinedValuesDoesNotMatch()
{
$rule = new KeyValue('foo', 'equals', 'bar');
2015-10-18 03:44:47 +02:00
$rule->check(['foo' => 43, 'bar' => 42]);
2015-10-08 18:54:42 +02:00
}
}