function FileViewsDataTest::testRelationshipViewsData

Same name in other branches
  1. 9 core/modules/options/tests/src/Kernel/Views/FileViewsDataTest.php \Drupal\Tests\options\Kernel\Views\FileViewsDataTest::testRelationshipViewsData()
  2. 10 core/modules/options/tests/src/Kernel/Views/FileViewsDataTest.php \Drupal\Tests\options\Kernel\Views\FileViewsDataTest::testRelationshipViewsData()
  3. 11.x core/modules/options/tests/src/Kernel/Views/FileViewsDataTest.php \Drupal\Tests\options\Kernel\Views\FileViewsDataTest::testRelationshipViewsData()

Tests views data generated for file field relationship.

See also

file_field_views_data()

file_field_views_data_views_data_alter()

File

core/modules/options/tests/src/Kernel/Views/FileViewsDataTest.php, line 39

Class

FileViewsDataTest
Tests file views data.

Namespace

Drupal\Tests\options\Kernel\Views

Code

public function testRelationshipViewsData() {
    // Create file field to entity_test.
    FieldStorageConfig::create([
        'entity_type' => 'entity_test',
        'field_name' => 'field_base_file',
        'type' => 'file',
    ])->save();
    FieldConfig::create([
        'entity_type' => 'entity_test',
        'field_name' => 'field_base_file',
        'bundle' => 'entity_test',
    ])->save();
    // Check the generated views data.
    $views_data = Views::viewsData()->get('entity_test__field_base_file');
    $relationship = $views_data['field_base_file_target_id']['relationship'];
    $this->assertEqual($relationship['id'], 'standard');
    $this->assertEqual($relationship['base'], 'file_managed');
    $this->assertEqual($relationship['base field'], 'fid');
    $this->assertEqual($relationship['entity type'], 'file');
    // Check the backwards reference.
    $views_data = Views::viewsData()->get('file_managed');
    $relationship = $views_data['reverse_field_base_file_entity_test']['relationship'];
    $this->assertEqual($relationship['id'], 'entity_reverse');
    $this->assertEqual($relationship['base'], 'entity_test');
    $this->assertEqual($relationship['base field'], 'id');
    $this->assertEqual($relationship['field table'], 'entity_test__field_base_file');
    $this->assertEqual($relationship['field field'], 'field_base_file_target_id');
    $this->assertEqual($relationship['field_name'], 'field_base_file');
    $this->assertEqual($relationship['entity_type'], 'entity_test');
    $this->assertEqual($relationship['join_extra'][0], [
        'field' => 'deleted',
        'value' => 0,
        'numeric' => TRUE,
    ]);
    // Create file field to entity_test_mul.
    FieldStorageConfig::create([
        'entity_type' => 'entity_test_mul',
        'field_name' => 'field_data_file',
        'type' => 'file',
    ])->save();
    FieldConfig::create([
        'entity_type' => 'entity_test_mul',
        'field_name' => 'field_data_file',
        'bundle' => 'entity_test_mul',
    ])->save();
    // Check the generated views data.
    $views_data = Views::viewsData()->get('entity_test_mul__field_data_file');
    $relationship = $views_data['field_data_file_target_id']['relationship'];
    $this->assertEqual($relationship['id'], 'standard');
    $this->assertEqual($relationship['base'], 'file_managed');
    $this->assertEqual($relationship['base field'], 'fid');
    $this->assertEqual($relationship['entity type'], 'file');
    // Check the backwards reference.
    $views_data = Views::viewsData()->get('file_managed');
    $relationship = $views_data['reverse_field_data_file_entity_test_mul']['relationship'];
    $this->assertEqual($relationship['id'], 'entity_reverse');
    $this->assertEqual($relationship['base'], 'entity_test_mul_property_data');
    $this->assertEqual($relationship['base field'], 'id');
    $this->assertEqual($relationship['field table'], 'entity_test_mul__field_data_file');
    $this->assertEqual($relationship['field field'], 'field_data_file_target_id');
    $this->assertEqual($relationship['field_name'], 'field_data_file');
    $this->assertEqual($relationship['entity_type'], 'entity_test_mul');
    $this->assertEqual($relationship['join_extra'][0], [
        'field' => 'deleted',
        'value' => 0,
        'numeric' => TRUE,
    ]);
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.