respect-validation/tests/unit/Rules/AbstractRuleTest.php
Henrique Moody fd2bae7352
Enforce the use of "@covers" annotation
Signed-off-by: Henrique Moody <henriquemoody@gmail.com>
2018-07-23 21:37:38 +02:00

187 lines
4.9 KiB
PHP

<?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.
*/
declare(strict_types=1);
namespace Respect\Validation\Rules;
use PHPUnit\Framework\TestCase;
use Respect\Validation\Exceptions\ValidationException;
/**
* @covers \Respect\Validation\Rules\AbstractRule
*/
class AbstractRuleTest extends TestCase
{
public function providerForTrueAndFalse()
{
return [
[true],
[false],
];
}
/**
* @dataProvider providerForTrueAndFalse
* @covers \Respect\Validation\Rules\AbstractRule::__invoke
*
* @test
*/
public function magicMethodInvokeCallsValidateWithInput($booleanResult): void
{
$input = 'something';
$abstractRuleMock = $this
->getMockBuilder(AbstractRule::class)
->setMethods(['validate'])
->getMockForAbstractClass();
$abstractRuleMock
->expects(self::once())
->method('validate')
->with($input)
->will(self::returnValue($booleanResult));
self::assertEquals(
$booleanResult,
// Invoking it to trigger __invoke
$abstractRuleMock($input),
'When invoking an instance of AbstractRule, the method validate should be called with the same input and return the same result.'
);
}
/**
* @covers \Respect\Validation\Rules\AbstractRule::assert
*
* @test
*/
public function assertInvokesValidateOnSuccess(): void
{
$input = 'something';
$abstractRuleMock = $this
->getMockBuilder(AbstractRule::class)
->setMethods(['validate', 'reportError'])
->getMockForAbstractClass();
$abstractRuleMock
->expects(self::once())
->method('validate')
->with($input)
->will(self::returnValue(true));
$abstractRuleMock
->expects(self::never())
->method('reportError');
$abstractRuleMock->assert($input);
}
/**
* @covers \Respect\Validation\Rules\AbstractRule::assert
* @expectedException \Respect\Validation\Exceptions\ValidationException
*
* @test
*/
public function assertInvokesValidateAndReportErrorOnFailure(): void
{
$input = 'something';
$abstractRuleMock = $this
->getMockBuilder(AbstractRule::class)
->setMethods(['validate', 'reportError'])
->getMockForAbstractClass();
$abstractRuleMock
->expects(self::once())
->method('validate')
->with($input)
->will(self::returnValue(false));
$abstractRuleMock
->expects(self::once())
->method('reportError')
->with($input)
->will(self::throwException(new ValidationException($input, 'abstract', [], 'trim')));
$abstractRuleMock->assert($input);
}
/**
* @covers \Respect\Validation\Rules\AbstractRule::check
*
* @test
*/
public function checkInvokesAssertToPerformTheValidationByDefault(): void
{
$input = 'something';
$abstractRuleMock = $this
->getMockBuilder(AbstractRule::class)
->setMethods(['assert'])
->getMockForAbstractClass();
$abstractRuleMock
->expects(self::once())
->method('assert')
->with($input);
$abstractRuleMock->check($input);
}
/**
* @covers \Respect\Validation\Rules\AbstractRule::setTemplate
*
* @test
*/
public function shouldReturnTheCurrentObjectWhenDefinigTemplate(): void
{
$abstractRuleMock = $this
->getMockBuilder(AbstractRule::class)
->getMockForAbstractClass();
self::assertSame($abstractRuleMock, $abstractRuleMock->setTemplate('whatever'));
}
/**
* @covers \Respect\Validation\Rules\AbstractRule::setName
*
* @test
*/
public function shouldReturnTheCurrentObjectWhenDefinigName(): void
{
$abstractRuleMock = $this
->getMockBuilder(AbstractRule::class)
->getMockForAbstractClass();
self::assertSame($abstractRuleMock, $abstractRuleMock->setName('whatever'));
}
/**
* @covers \Respect\Validation\Rules\AbstractRule::getName
* @covers \Respect\Validation\Rules\AbstractRule::setName
*
* @test
*/
public function shouldBeAbleToDefineAndRetrivedRuleName(): void
{
$abstractRuleMock = $this
->getMockBuilder(AbstractRule::class)
->getMockForAbstractClass();
$name = 'something';
$abstractRuleMock->setName($name);
self::assertSame($name, $abstractRuleMock->getName());
}
}