You are here

public function ComplexDataConstraintValidatorTest::testValidation in Zircon Profile 8

Same name and namespace in other branches
  1. 8.0 core/modules/system/src/Tests/Validation/ComplexDataConstraintValidatorTest.php \Drupal\system\Tests\Validation\ComplexDataConstraintValidatorTest::testValidation()

Tests the ComplexData validation constraint validator.

For testing a map including a constraint on one of its keys is defined.

File

core/modules/system/src/Tests/Validation/ComplexDataConstraintValidatorTest.php, line 39
Contains \Drupal\system\Tests\Validation\ComplexDataConstraintValidatorTest.

Class

ComplexDataConstraintValidatorTest
Tests ComplexData validation constraint with both valid and invalid values for a key.

Namespace

Drupal\system\Tests\Validation

Code

public function testValidation() {

  // Create a definition that specifies some ComplexData constraint.
  $definition = MapDataDefinition::create()
    ->setPropertyDefinition('key', DataDefinition::create('integer'))
    ->addConstraint('ComplexData', array(
    'key' => array(
      'AllowedValues' => array(
        1,
        2,
        3,
      ),
    ),
  ));

  // Test the validation.
  $typed_data = $this->typedData
    ->create($definition, array(
    'key' => 1,
  ));
  $violations = $typed_data
    ->validate();
  $this
    ->assertEqual($violations
    ->count(), 0, 'Validation passed for correct value.');

  // Test the validation when an invalid value is passed.
  $typed_data = $this->typedData
    ->create($definition, array(
    'key' => 4,
  ));
  $violations = $typed_data
    ->validate();
  $this
    ->assertEqual($violations
    ->count(), 1, 'Validation failed for incorrect value.');

  // Make sure the information provided by a violation is correct.
  $violation = $violations[0];
  $this
    ->assertEqual($violation
    ->getMessage(), t('The value you selected is not a valid choice.'), 'The message for invalid value is correct.');
  $this
    ->assertEqual($violation
    ->getRoot(), $typed_data, 'Violation root is correct.');
  $this
    ->assertEqual($violation
    ->getInvalidValue(), 4, 'The invalid value is set correctly in the violation.');

  // Test using the constraint with a map without the specified key. This
  // should be ignored as long as there is no NotNull or NotBlank constraint.
  $typed_data = $this->typedData
    ->create($definition, array(
    'foo' => 'bar',
  ));
  $violations = $typed_data
    ->validate();
  $this
    ->assertEqual($violations
    ->count(), 0, 'Constraint on non-existing key is ignored.');
  $definition = MapDataDefinition::create()
    ->setPropertyDefinition('key', DataDefinition::create('integer'))
    ->addConstraint('ComplexData', array(
    'key' => array(
      'NotNull' => array(),
    ),
  ));
  $typed_data = $this->typedData
    ->create($definition, array(
    'foo' => 'bar',
  ));
  $violations = $typed_data
    ->validate();
  $this
    ->assertEqual($violations
    ->count(), 1, 'Key is required.');
}