You are here

EntityReferenceRdfaTest.php in Zircon Profile 8.0

Same filename and directory in other branches
  1. 8 core/modules/rdf/src/Tests/Field/EntityReferenceRdfaTest.php

File

core/modules/rdf/src/Tests/Field/EntityReferenceRdfaTest.php
View source
<?php

/**
 * @file
 * Contains \Drupal\rdf\Tests\Field\EntityReferenceRdfaTest.
 */
namespace Drupal\rdf\Tests\Field;

use Drupal\field\Tests\EntityReference\EntityReferenceTestTrait;
use Drupal\user\Entity\Role;
use Drupal\user\RoleInterface;

/**
 * Tests the RDFa output of the entity reference field formatter.
 *
 * @group rdf
 */
class EntityReferenceRdfaTest extends FieldRdfaTestBase {
  use EntityReferenceTestTrait;

  /**
   * {@inheritdoc}
   */
  protected $fieldType = 'entity_reference';

  /**
   * The entity type used in this test.
   *
   * @var string
   */
  protected $entityType = 'entity_test';

  /**
   * The bundle used in this test.
   *
   * @var string
   */
  protected $bundle = 'entity_test';

  /**
   * The term for testing.
   *
   * @var \Drupal\taxonomy\Entity\Term
   */
  protected $targetEntity;

  /**
   * {@inheritdoc}
   */
  public static $modules = [
    'text',
    'filter',
  ];
  protected function setUp() {
    parent::setUp();
    $this
      ->installEntitySchema('entity_test_rev');

    // Give anonymous users permission to view test entities.
    $this
      ->installConfig(array(
      'user',
    ));
    Role::load(RoleInterface::ANONYMOUS_ID)
      ->grantPermission('view test entity')
      ->save();
    $this
      ->createEntityReferenceField($this->entityType, $this->bundle, $this->fieldName, 'Field test', $this->entityType);

    // Add the mapping.
    $mapping = rdf_get_mapping('entity_test', 'entity_test');
    $mapping
      ->setFieldMapping($this->fieldName, array(
      'properties' => array(
        'schema:knows',
      ),
    ))
      ->save();

    // Create the entity to be referenced.
    $this->targetEntity = entity_create($this->entityType, array(
      'name' => $this
        ->randomMachineName(),
    ));
    $this->targetEntity
      ->save();

    // Create the entity that will have the entity reference field.
    $this->entity = entity_create($this->entityType, array(
      'name' => $this
        ->randomMachineName(),
    ));
    $this->entity
      ->save();
    $this->entity->{$this->fieldName}->entity = $this->targetEntity;
    $this->uri = $this
      ->getAbsoluteUri($this->entity);
  }

  /**
   * Tests all the entity reference formatters.
   */
  public function testAllFormatters() {
    $entity_uri = $this
      ->getAbsoluteUri($this->targetEntity);

    // Tests the label formatter.
    $this
      ->assertFormatterRdfa(array(
      'type' => 'entity_reference_label',
    ), 'http://schema.org/knows', array(
      'value' => $entity_uri,
      'type' => 'uri',
    ));

    // Tests the entity formatter.
    $this
      ->assertFormatterRdfa(array(
      'type' => 'entity_reference_entity_view',
    ), 'http://schema.org/knows', array(
      'value' => $entity_uri,
      'type' => 'uri',
    ));
  }

}

Classes

Namesort descending Description
EntityReferenceRdfaTest Tests the RDFa output of the entity reference field formatter.