You are here

public function SqlContentEntityStorageTest::testGetTableMappingTranslatableWithFields in Drupal 8

Same name and namespace in other branches
  1. 9 core/tests/Drupal/Tests/Core/Entity/Sql/SqlContentEntityStorageTest.php \Drupal\Tests\Core\Entity\Sql\SqlContentEntityStorageTest::testGetTableMappingTranslatableWithFields()

Tests getTableMapping() with a translatable entity type with fields.

@covers ::__construct @covers ::getTableMapping

@dataProvider providerTestGetTableMappingSimple()

Parameters

string[] $entity_keys: A map of entity keys to use for the mocked entity type.

File

core/tests/Drupal/Tests/Core/Entity/Sql/SqlContentEntityStorageTest.php, line 772
Contains \Drupal\Tests\Core\Entity\Sql\SqlContentEntityStorageTest.

Class

SqlContentEntityStorageTest
@coversDefaultClass \Drupal\Core\Entity\Sql\SqlContentEntityStorage @group Entity

Namespace

Drupal\Tests\Core\Entity\Sql

Code

public function testGetTableMappingTranslatableWithFields(array $entity_keys) {

  // This allows to re-use the data provider.
  $entity_keys['langcode'] = 'langcode';
  $base_field_names = [
    'title',
    'description',
    'owner',
  ];
  $field_names = array_merge(array_values(array_filter($entity_keys)), $base_field_names);
  $this->fieldDefinitions = $this
    ->mockFieldDefinitions($field_names);
  $this->entityType
    ->expects($this
    ->atLeastOnce())
    ->method('isTranslatable')
    ->will($this
    ->returnValue(TRUE));
  $this->entityType
    ->expects($this
    ->atLeastOnce())
    ->method('getDataTable')
    ->will($this
    ->returnValue('entity_test_field_data'));
  $this->entityType
    ->expects($this
    ->any())
    ->method('getKey')
    ->will($this
    ->returnValueMap([
    [
      'id',
      $entity_keys['id'],
    ],
    [
      'uuid',
      $entity_keys['uuid'],
    ],
    [
      'bundle',
      $entity_keys['bundle'],
    ],
    [
      'langcode',
      $entity_keys['langcode'],
    ],
  ]));
  $this
    ->setUpEntityStorage();
  $mapping = $this->entityStorage
    ->getTableMapping();
  $expected = [
    'entity_test',
    'entity_test_field_data',
  ];
  $this
    ->assertEquals($expected, $mapping
    ->getTableNames());
  $expected = array_values(array_filter($entity_keys));
  $actual = $mapping
    ->getFieldNames('entity_test');
  $this
    ->assertEquals($expected, $actual);

  // The UUID is not stored on the data table.
  $expected = array_merge(array_filter([
    $entity_keys['id'],
    $entity_keys['bundle'],
    $entity_keys['langcode'],
  ]), $base_field_names);
  $actual = $mapping
    ->getFieldNames('entity_test_field_data');
  $this
    ->assertEquals($expected, $actual);
  $expected = [];
  $actual = $mapping
    ->getExtraColumns('entity_test');
  $this
    ->assertEquals($expected, $actual);
  $actual = $mapping
    ->getExtraColumns('entity_test_field_data');
  $this
    ->assertEquals($expected, $actual);
}