class EntityConstraintViolationListTest in Zircon Profile 8
Same name and namespace in other branches
- 8.0 core/tests/Drupal/Tests/Core/Entity/EntityConstraintViolationListTest.php \Drupal\Tests\Core\Entity\EntityConstraintViolationListTest
 
@coversDefaultClass \Drupal\Core\Entity\EntityConstraintViolationList @group entity
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \Drupal\Tests\PHPUnit_Framework_TestCase
- class \Drupal\Tests\Core\Entity\EntityConstraintViolationListTest
 
 
Expanded class hierarchy of EntityConstraintViolationListTest
File
- core/
tests/ Drupal/ Tests/ Core/ Entity/ EntityConstraintViolationListTest.php, line 21  - Contains \Drupal\Tests\Core\Entity\EntityConstraintViolationListTest.
 
Namespace
Drupal\Tests\Core\EntityView source
class EntityConstraintViolationListTest extends UnitTestCase {
  /**
   * @covers ::filterByFields
   */
  public function testFilterByFields() {
    $account = $this
      ->prophesize('\\Drupal\\Core\\Session\\AccountInterface')
      ->reveal();
    $entity = $this
      ->setupEntity($account);
    $constraint_list = $this
      ->setupConstraintListWithoutCompositeConstraint($entity);
    $violations = iterator_to_array($constraint_list);
    $this
      ->assertSame($constraint_list
      ->filterByFields([
      'name',
    ]), $constraint_list);
    $this
      ->assertCount(4, $constraint_list);
    $this
      ->assertArrayEquals(array_values(iterator_to_array($constraint_list)), [
      $violations[2],
      $violations[3],
      $violations[4],
      $violations[5],
    ]);
  }
  /**
   * @covers ::filterByFields
   */
  public function testFilterByFieldsWithCompositeConstraints() {
    $account = $this
      ->prophesize('\\Drupal\\Core\\Session\\AccountInterface')
      ->reveal();
    $entity = $this
      ->setupEntity($account);
    $constraint_list = $this
      ->setupConstraintListWithCompositeConstraint($entity);
    $violations = iterator_to_array($constraint_list);
    $this
      ->assertSame($constraint_list
      ->filterByFields([
      'name',
    ]), $constraint_list);
    $this
      ->assertCount(4, $constraint_list);
    $this
      ->assertArrayEquals(array_values(iterator_to_array($constraint_list)), [
      $violations[2],
      $violations[3],
      $violations[4],
      $violations[5],
    ]);
  }
  /**
   * @covers ::filterByFieldAccess
   */
  public function testFilterByFieldAccess() {
    $account = $this
      ->prophesize('\\Drupal\\Core\\Session\\AccountInterface')
      ->reveal();
    $entity = $this
      ->setupEntity($account);
    $constraint_list = $this
      ->setupConstraintListWithoutCompositeConstraint($entity);
    $violations = iterator_to_array($constraint_list);
    $this
      ->assertSame($constraint_list
      ->filterByFieldAccess($account), $constraint_list);
    $this
      ->assertCount(4, $constraint_list);
    $this
      ->assertArrayEquals(array_values(iterator_to_array($constraint_list)), [
      $violations[2],
      $violations[3],
      $violations[4],
      $violations[5],
    ]);
  }
  /**
   * @covers ::filterByFieldAccess
   */
  public function testFilterByFieldAccessWithCompositeConstraint() {
    $account = $this
      ->prophesize('\\Drupal\\Core\\Session\\AccountInterface')
      ->reveal();
    $entity = $this
      ->setupEntity($account);
    $constraint_list = $this
      ->setupConstraintListWithCompositeConstraint($entity);
    $violations = iterator_to_array($constraint_list);
    $this
      ->assertSame($constraint_list
      ->filterByFieldAccess($account), $constraint_list);
    $this
      ->assertCount(4, $constraint_list);
    $this
      ->assertArrayEquals(array_values(iterator_to_array($constraint_list)), [
      $violations[2],
      $violations[3],
      $violations[4],
      $violations[5],
    ]);
  }
  /**
   * Builds the entity.
   *
   * @param \Drupal\Core\Session\AccountInterface $account
   *   An account.
   *
   * @return \Drupal\Core\Field\FieldItemListInterface
   *   A fieldable entity.
   */
  protected function setupEntity(AccountInterface $account) {
    $prophecy = $this
      ->prophesize('\\Drupal\\Core\\Field\\FieldItemListInterface');
    $prophecy
      ->access('edit', $account)
      ->willReturn(FALSE);
    $name_field_item_list = $prophecy
      ->reveal();
    $prophecy = $this
      ->prophesize('\\Drupal\\Core\\Field\\FieldItemListInterface');
    $prophecy
      ->access('edit', $account)
      ->willReturn(TRUE);
    $type_field_item_list = $prophecy
      ->reveal();
    $prophecy = $this
      ->prophesize('\\Drupal\\Core\\Entity\\FieldableEntityInterface');
    $prophecy
      ->hasField('name')
      ->willReturn(TRUE);
    $prophecy
      ->hasField('type')
      ->willReturn(TRUE);
    $prophecy
      ->get('name')
      ->willReturn($name_field_item_list);
    $prophecy
      ->get('type')
      ->willReturn($type_field_item_list);
    return $prophecy
      ->reveal();
  }
  /**
   * Builds an entity constraint violation list without composite constraints.
   *
   * @param \Drupal\Core\Entity\FieldableEntityInterface $entity
   *   A fieldable entity.
   *
   * @return \Drupal\Core\Entity\EntityConstraintViolationList
   *   The entity constraint violation list.
   */
  protected function setupConstraintListWithoutCompositeConstraint(FieldableEntityInterface $entity) {
    $violations = [];
    // Add two violations to two specific fields.
    $violations[] = new ConstraintViolation('test name violation', '', [], '', 'name', 'invalid');
    $violations[] = new ConstraintViolation('test name violation2', '', [], '', 'name', 'invalid');
    $violations[] = new ConstraintViolation('test type violation', '', [], '', 'type', 'invalid');
    $violations[] = new ConstraintViolation('test type violation2', '', [], '', 'type', 'invalid');
    // Add two entity level specific violations.
    $violations[] = new ConstraintViolation('test entity violation', '', [], '', '', 'invalid');
    $violations[] = new ConstraintViolation('test entity violation2', '', [], '', '', 'invalid');
    return new EntityConstraintViolationList($entity, $violations);
  }
  /**
   * Builds an entity constraint violation list with composite constraints.
   *
   * @param \Drupal\Core\Entity\FieldableEntityInterface $entity
   *   A fieldable entity.
   *
   * @return \Drupal\Core\Entity\EntityConstraintViolationList
   *   The entity constraint violation list.
   */
  protected function setupConstraintListWithCompositeConstraint(FieldableEntityInterface $entity) {
    $violations = [];
    // Add two violations to two specific fields.
    $violations[] = new ConstraintViolation('test name violation', '', [], '', 'name', 'invalid');
    $violations[] = new ConstraintViolation('test name violation2', '', [], '', 'name', 'invalid');
    $violations[] = new ConstraintViolation('test type violation', '', [], '', 'type', 'invalid');
    $violations[] = new ConstraintViolation('test type violation2', '', [], '', 'type', 'invalid');
    // Add two entity level specific violations with a compound constraint.
    $composite_constraint = new EntityTestCompositeConstraint();
    $violations[] = new ConstraintViolation('test composite violation', '', [], '', '', 'invalid', NULL, NULL, $composite_constraint);
    $violations[] = new ConstraintViolation('test composite violation2', '', [], '', '', 'invalid', NULL, NULL, $composite_constraint);
    return new EntityConstraintViolationList($entity, $violations);
  }
}Members
| 
            Name | 
                  Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| 
            EntityConstraintViolationListTest:: | 
                  protected | function | Builds an entity constraint violation list with composite constraints. | |
| 
            EntityConstraintViolationListTest:: | 
                  protected | function | Builds an entity constraint violation list without composite constraints. | |
| 
            EntityConstraintViolationListTest:: | 
                  protected | function | Builds the entity. | |
| 
            EntityConstraintViolationListTest:: | 
                  public | function | @covers ::filterByFieldAccess | |
| 
            EntityConstraintViolationListTest:: | 
                  public | function | @covers ::filterByFieldAccess | |
| 
            EntityConstraintViolationListTest:: | 
                  public | function | @covers ::filterByFields | |
| 
            EntityConstraintViolationListTest:: | 
                  public | function | @covers ::filterByFields | |
| 
            UnitTestCase:: | 
                  protected | property | The random generator. | |
| 
            UnitTestCase:: | 
                  protected | property | The app root. | |
| 
            UnitTestCase:: | 
                  protected | function | Asserts if two arrays are equal by sorting them first. | |
| 
            UnitTestCase:: | 
                  protected | function | Mocks a block with a block plugin. | |
| 
            UnitTestCase:: | 
                  protected | function | Returns a stub class resolver. | |
| 
            UnitTestCase:: | 
                  public | function | Returns a stub config factory that behaves according to the passed in array. | |
| 
            UnitTestCase:: | 
                  public | function | Returns a stub config storage that returns the supplied configuration. | |
| 
            UnitTestCase:: | 
                  protected | function | Sets up a container with a cache tags invalidator. | |
| 
            UnitTestCase:: | 
                  protected | function | Gets the random generator for the utility methods. | |
| 
            UnitTestCase:: | 
                  public | function | Returns a stub translation manager that just returns the passed string. | |
| 
            UnitTestCase:: | 
                  public | function | Generates a unique random string containing letters and numbers. | |
| 
            UnitTestCase:: | 
                  protected | function | 259 |