respect-validation/tests/unit/Rules/AttributeTest.php
Henrique Moody b7043b2652
Set up "squizlabs/php_codesniffer"
The tool we used to verify whether the code base has the correct coding
standard was removed [1].

This commit will set up one that works best for us and will also make
sure we have fully compliant to PS1 and PSR2.

[1]: ffec95acda

Signed-off-by: Henrique Moody <henriquemoody@gmail.com>
2019-02-03 19:39:14 +01:00

88 lines
2.7 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 Respect\Validation\Test\RuleTestCase;
use Respect\Validation\Validatable;
/**
* @group rule
* @covers \Respect\Validation\Exceptions\AttributeException
* @covers \Respect\Validation\Rules\Attribute
*
* @author Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
* @author Emmerson Siqueira <emmersonsiqueira@gmail.com>
* @author Gabriel Caruso <carusogabriel34@gmail.com>
* @author Henrique Moody <henriquemoody@gmail.com>
*/
final class AttributeTest extends RuleTestCase
{
/**
* {@inheritdoc}
*/
public function providerForValidInput(): array
{
$obj = new \stdClass();
$obj->bar = 'foo';
$extraValidator = $this->createMock(Validatable::class);
$extraValidator->method('validate')
->willReturn(true);
return [
'attribute is present without extra validator' => [new Attribute('bar'), $obj],
'private attribute is present without extra validator' => [
new Attribute('bar'),
$this->objectWithPrivateProperty()
],
'attribute is present with extra validator' => [new Attribute('bar', $extraValidator), $obj],
'non mandatory attribute is not present' => [new Attribute('foo', null, false), $obj],
'non mandatory attribute is not present with extra validator' => [
new Attribute('foo', $extraValidator, false),
$obj
],
];
}
/**
* {@inheritdoc}
*/
public function providerForInvalidInput(): array
{
$obj = new \stdClass();
$obj->bar = 'foo';
$extraValidatorMock = $this->createMock(Validatable::class);
$extraValidatorMock->method('validate')->willReturn(false);
return [
'attribute is absent without extra validator' => [new Attribute('barr'), $obj],
'private attribute is not valid based on extra validator' => [
new Attribute('bar', $extraValidatorMock),
$this->objectWithPrivateProperty()
],
'value provided is an empty string' => [new Attribute('barr'), ''],
'validator related to attribute does not validate' => [new Attribute('bar', $extraValidatorMock), $obj],
];
}
private function objectWithPrivateProperty()
{
return new class() {
public const PROPERTY_VALUE = 'foo';
private $bar = self::PROPERTY_VALUE;
};
}
}