DigiComp.SettingValidator/Tests/Functional/SettingsValidatorTest.php

71 lines
3 KiB
PHP
Raw Normal View History

2017-06-02 21:58:33 +02:00
<?php
2020-03-10 14:48:57 +01:00
2017-06-02 21:58:33 +02:00
namespace DigiComp\SettingValidator\Tests\Functional;
use DigiComp\SettingValidator\Tests\Functional\Fixtures\TestObject;
use DigiComp\SettingValidator\Tests\Functional\Fixtures\TestValidationGroupsCustomObject;
use DigiComp\SettingValidator\Tests\Functional\Fixtures\TestValidationGroupsDefaultObject;
2017-06-02 21:58:33 +02:00
use DigiComp\SettingValidator\Validation\Validator\SettingsValidator;
use Neos\Flow\Tests\FunctionalTestCase;
2020-05-14 14:43:09 +02:00
use Neos\Flow\Validation\Exception\InvalidValidationConfigurationException;
use Neos\Flow\Validation\Exception\InvalidValidationOptionsException;
use Neos\Flow\Validation\Exception\NoSuchValidatorException;
2017-06-02 21:58:33 +02:00
use Neos\Flow\Validation\ValidatorResolver;
class SettingsValidatorTest extends FunctionalTestCase
{
/**
* @test
2020-05-14 14:43:09 +02:00
* @throws InvalidValidationOptionsException
2017-06-02 21:58:33 +02:00
*/
2020-07-22 17:22:46 +02:00
public function ifNoNameIsGivenClassNameIsUsed(): void
2017-06-02 21:58:33 +02:00
{
$validator = $this->objectManager->get(SettingsValidator::class);
$result = $validator->validate(new TestObject());
$this->assertTrue($result->hasErrors());
$this->assertCount(1, $result->getFlattenedErrors());
$this->assertCount(1, $result->forProperty('shouldBeFalse')->getErrors());
}
/**
* @test
2020-05-14 14:43:09 +02:00
* @throws InvalidValidationConfigurationException
* @throws InvalidValidationOptionsException
* @throws NoSuchValidatorException
2017-06-02 21:58:33 +02:00
*/
2020-07-22 17:22:46 +02:00
public function conjunctionValidationWorksAsExpected(): void
2017-06-02 21:58:33 +02:00
{
$validatorResolver = $this->objectManager->get(ValidatorResolver::class);
$validator = $validatorResolver->getBaseValidatorConjunction(TestObject::class);
$result = $validator->validate(new TestObject());
$this->assertTrue($result->hasErrors());
$this->assertCount(1, $result->getFlattenedErrors());
}
/**
* @test
2020-05-14 14:43:09 +02:00
* @throws InvalidValidationOptionsException
*/
2020-07-22 17:22:46 +02:00
public function defaultValidationGroupWorks(): void
{
$validator = $this->objectManager->get(SettingsValidator::class, ['validationGroups' => ['Default']]);
$result = $validator->validate(new TestValidationGroupsDefaultObject());
$this->assertTrue($result->hasErrors(), 'No Errors for validation group "Default"');
$this->assertCount(1, $result->getFlattenedErrors(), 'Got a non expected number of errors for group "Default"');
2017-07-19 12:55:31 +02:00
$this->assertCount(1, $result->forProperty('shouldBeTrue')->getErrors(), 'Got no error for property');
}
/**
* @test
2020-05-14 14:43:09 +02:00
* @throws InvalidValidationOptionsException
*/
2020-07-22 17:22:46 +02:00
public function customValidationGroupWorks(): void
{
$validator = $this->objectManager->get(SettingsValidator::class, ['validationGroups' => ['Custom']]);
$result = $validator->validate(new TestValidationGroupsCustomObject());
$this->assertTrue($result->hasErrors(), 'No Errors for validation group "Custom"');
$this->assertCount(1, $result->getFlattenedErrors(), 'Got a non expected number of errors for group "Custom"');
2017-07-19 12:55:31 +02:00
$this->assertCount(1, $result->forProperty('shouldBeFalse')->getErrors(), 'Got no error for property');
}
2017-06-02 21:58:33 +02:00
}