trait EntityReferenceTestTrait

Same name in this branch
  1. 8.9.x core/modules/field/src/Tests/EntityReference/EntityReferenceTestTrait.php \Drupal\field\Tests\EntityReference\EntityReferenceTestTrait
Same name in other branches
  1. 9 core/modules/field/tests/src/Traits/EntityReferenceTestTrait.php \Drupal\Tests\field\Traits\EntityReferenceTestTrait
  2. 10 core/modules/field/tests/src/Traits/EntityReferenceTestTrait.php \Drupal\Tests\field\Traits\EntityReferenceTestTrait
  3. 11.x core/modules/field/tests/src/Traits/EntityReferenceTestTrait.php \Drupal\Tests\field\Traits\EntityReferenceTestTrait

Provides common functionality for the EntityReference test classes.

Hierarchy

45 files declare their use of EntityReferenceTestTrait
CommonCollectionFilterAccessTestPatternsTrait.php in core/modules/jsonapi/tests/src/Traits/CommonCollectionFilterAccessTestPatternsTrait.php
ContentEntityTest.php in core/modules/migrate_drupal/tests/src/Kernel/Plugin/migrate/source/ContentEntityTest.php
ContentModerationTest.php in core/modules/media_library/tests/src/FunctionalJavascript/ContentModerationTest.php
DefaultViewsTest.php in core/modules/views/tests/src/Functional/DefaultViewsTest.php
DisplayEntityReferenceTest.php in core/modules/views/tests/src/Functional/Plugin/DisplayEntityReferenceTest.php

... See full list

File

core/modules/field/tests/src/Traits/EntityReferenceTestTrait.php, line 11

Namespace

Drupal\Tests\field\Traits
View source
trait EntityReferenceTestTrait {
    
    /**
     * Creates a field of an entity reference field storage on the specified bundle.
     *
     * @param string $entity_type
     *   The type of entity the field will be attached to.
     * @param string $bundle
     *   The bundle name of the entity the field will be attached to.
     * @param string $field_name
     *   The name of the field; if it already exists, a new instance of the existing
     *   field will be created.
     * @param string $field_label
     *   The label of the field.
     * @param string $target_entity_type
     *   The type of the referenced entity.
     * @param string $selection_handler
     *   The selection handler used by this field.
     * @param array $selection_handler_settings
     *   An array of settings supported by the selection handler specified above.
     *   (e.g. 'target_bundles', 'sort', 'auto_create', etc).
     * @param int $cardinality
     *   The cardinality of the field.
     *
     * @see \Drupal\Core\Entity\Plugin\EntityReferenceSelection\SelectionBase::buildConfigurationForm()
     */
    protected function createEntityReferenceField($entity_type, $bundle, $field_name, $field_label, $target_entity_type, $selection_handler = 'default', $selection_handler_settings = [], $cardinality = 1) {
        // Look for or add the specified field to the requested entity bundle.
        if (!FieldStorageConfig::loadByName($entity_type, $field_name)) {
            FieldStorageConfig::create([
                'field_name' => $field_name,
                'type' => 'entity_reference',
                'entity_type' => $entity_type,
                'cardinality' => $cardinality,
                'settings' => [
                    'target_type' => $target_entity_type,
                ],
            ])->save();
        }
        if (!FieldConfig::loadByName($entity_type, $bundle, $field_name)) {
            FieldConfig::create([
                'field_name' => $field_name,
                'entity_type' => $entity_type,
                'bundle' => $bundle,
                'label' => $field_label,
                'settings' => [
                    'handler' => $selection_handler,
                    'handler_settings' => $selection_handler_settings,
                ],
            ])->save();
        }
    }

}

Members

Title Sort descending Modifiers Object type Summary
EntityReferenceTestTrait::createEntityReferenceField protected function Creates a field of an entity reference field storage on the specified bundle.

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