1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\Validator\Tests\Constraints;
use Symfony\Component\Validator\Constraints\IsTrue;
use Symfony\Component\Validator\Constraints\IsTrueValidator;
use Symfony\Component\Validator\Test\ConstraintValidatorTestCase;
class IsTrueValidatorTest extends ConstraintValidatorTestCase
{
protected function createValidator(): IsTrueValidator
{
return new IsTrueValidator();
}
public function testNullIsValid()
{
$this->validator->validate(null, new IsTrue());
$this->assertNoViolation();
}
public function testTrueIsValid()
{
$this->validator->validate(true, new IsTrue());
$this->assertNoViolation();
}
#[\PHPUnit\Framework\Attributes\DataProvider('provideInvalidConstraints')]
public function testFalseIsInvalid(IsTrue $constraint)
{
$this->validator->validate(false, $constraint);
$this->buildViolation('myMessage')
->setParameter('{{ value }}', 'false')
->setCode(IsTrue::NOT_TRUE_ERROR)
->assertRaised();
}
public static function provideInvalidConstraints(): iterable
{
yield 'Doctrine style' => [new IsTrue([
'message' => 'myMessage',
])];
yield 'named parameters' => [new IsTrue(message: 'myMessage')];
}
}
|