respect-validation/tests/unit/Rules/AbstractCompositeTest.php
Alexandre Gomes Gaigalas ab3732f91f Use SPDX IDs for licensing
SPDX IDs are shorter than licensing notes previously used, and
adhere better to FOSS standards. It is also machine-readable.
2023-02-19 00:19:10 -03:00

201 lines
5 KiB
PHP

<?php
/*
* Copyright (c) Alexandre Gomes Gaigalas <alganet@gmail.com>
* SPDX-License-Identifier: MIT
*/
declare(strict_types=1);
namespace Respect\Validation\Rules;
use Respect\Validation\Test\TestCase;
use Respect\Validation\Validatable;
/**
* @group rule
*
* @covers \Respect\Validation\Rules\AbstractComposite
*
* @author Emmerson Siqueira <emmersonsiqueira@gmail.com>
* @author Gabriel Caruso <carusogabriel34@gmail.com>
* @author Henrique Moody <henriquemoody@gmail.com>
*/
final class AbstractCompositeTest extends TestCase
{
/**
* @test
*/
public function shouldDefineNameForInternalWhenAppendRuleToCompositeRule(): void
{
$ruleName = 'something';
$rule = $this->createMock(Validatable::class);
$rule
->expects(self::once())
->method('getName')
->will(self::returnValue(null));
$rule
->expects(self::once())
->method('setName')
->with($ruleName);
$sut = $this
->getMockBuilder(AbstractComposite::class)
->getMockForAbstractClass();
$sut->setName($ruleName);
$sut->addRule($rule);
}
/**
* @test
*/
public function shouldUpdateInternalRuleNameWhenNameIsUpdated(): void
{
$ruleName1 = 'something';
$ruleName2 = 'something else';
$rule = $this->createMock(Validatable::class);
$rule
->expects(self::exactly(2))
->method('getName')
->willReturnOnConsecutiveCalls(
null,
$ruleName1
);
$sut = $this
->getMockBuilder(AbstractComposite::class)
->getMockForAbstractClass();
$sut->setName($ruleName1);
$sut->addRule($rule);
$sut->setName($ruleName2);
}
/**
* @test
*/
public function shouldNotUpdateInternalRuleWhenItAlreadyHasName(): void
{
$rule = $this->createMock(Validatable::class);
$rule
->expects(self::any())
->method('getName')
->will(self::returnValue('something'));
$rule
->expects(self::never())
->method('setName');
$sut = $this
->getMockBuilder(AbstractComposite::class)
->getMockForAbstractClass();
$sut->addRule($rule);
$sut->setName('Whatever');
}
/**
* @test
*/
public function shouldUpdateInternalRuleWhenItsNameIsNull(): void
{
$ruleName = 'something';
$rule = $this->createMock(Validatable::class);
$rule
->expects(self::any())
->method('getName')
->will(self::returnValue(null));
$rule
->expects(self::once())
->method('setName')
->with($ruleName);
$sut = $this
->getMockBuilder(AbstractComposite::class)
->getMockForAbstractClass();
$sut->addRule($rule);
$sut->setName($ruleName);
}
/**
* @test
*/
public function shouldDefineNameForInternalRulesWhenItDoesNotHaveName(): void
{
$ruleName = 'something';
$rule = $this->createMock(Validatable::class);
$rule
->expects(self::any())
->method('getName')
->will(self::returnValue(null));
$rule
->expects(self::once())
->method('setName')
->with($ruleName);
$sut = $this
->getMockBuilder(AbstractComposite::class)
->getMockForAbstractClass();
$sut->addRule($rule);
$sut->setName($ruleName);
}
/**
* @test
*/
public function shouldNotDefineNameForInternalRulesWhenItAlreadyHasName(): void
{
$ruleName = 'something';
$rule = $this->createMock(Validatable::class);
$rule
->expects(self::any())
->method('getName')
->will(self::returnValue($ruleName));
$rule
->expects(self::never())
->method('setName');
$sut = $this
->getMockBuilder(AbstractComposite::class)
->getMockForAbstractClass();
$sut->addRule($rule);
$sut->setName($ruleName);
}
/**
* @test
*/
public function shouldReturnTheAmountOfAddedRules(): void
{
$sut = $this->getMockForAbstractClass(AbstractComposite::class);
$sut->addRule($this->createMock(Validatable::class));
$sut->addRule($this->createMock(Validatable::class));
$sut->addRule($this->createMock(Validatable::class));
self::assertCount(3, $sut->getRules());
}
/**
* @test
*/
public function shouldAddRulesByPassingThroughConstructor(): void
{
$rule = $this->createMock(Validatable::class);
$anotherSimpleRuleMock = $this->createMock(Validatable::class);
$sut = $this->getMockForAbstractClass(AbstractComposite::class, [
$rule,
$anotherSimpleRuleMock,
]);
self::assertCount(2, $sut->getRules());
}
}