You are here

class EntityConverterTest in Drupal 10

Same name in this branch
  1. 10 core/tests/Drupal/Tests/Core/ParamConverter/EntityConverterTest.php \Drupal\Tests\Core\ParamConverter\EntityConverterTest
  2. 10 core/tests/Drupal/KernelTests/Core/ParamConverter/EntityConverterTest.php \Drupal\KernelTests\Core\ParamConverter\EntityConverterTest
Same name and namespace in other branches
  1. 9 core/tests/Drupal/KernelTests/Core/ParamConverter/EntityConverterTest.php \Drupal\KernelTests\Core\ParamConverter\EntityConverterTest

Tests the entity param converter.

@group ParamConverter @coversDefaultClass \Drupal\Core\ParamConverter\EntityConverter

Hierarchy

Expanded class hierarchy of EntityConverterTest

File

core/tests/Drupal/KernelTests/Core/ParamConverter/EntityConverterTest.php, line 17

Namespace

Drupal\KernelTests\Core\ParamConverter
View source
class EntityConverterTest extends KernelTestBase {
  use UserCreationTrait;

  /**
   * {@inheritdoc}
   */
  protected static $modules = [
    'entity_test',
    'user',
  ];

  /**
   * {@inheritdoc}
   */
  protected function setUp() : void {
    parent::setUp();
    $this
      ->setUpCurrentUser();
    $this
      ->installEntitySchema('entity_test');

    // Create some testing bundles for 'entity_test' entity type.
    entity_test_create_bundle('foo', 'Foo');
    entity_test_create_bundle('bar', 'Bar');
    entity_test_create_bundle('baz', 'Baz');
  }

  /**
   * Tests an entity route parameter having 'bundle' definition property.
   *
   * @covers ::convert
   */
  public function testRouteParamWithBundleDefinition() : void {
    $converter = $this->container
      ->get('paramconverter.entity');
    $entity1 = EntityTest::create([
      'name' => $this
        ->randomString(),
      'type' => 'foo',
    ]);
    $entity1
      ->save();
    $entity2 = EntityTest::create([
      'name' => $this
        ->randomString(),
      'type' => 'bar',
    ]);
    $entity2
      ->save();
    $entity3 = EntityTest::create([
      'name' => $this
        ->randomString(),
      'type' => 'baz',
    ]);
    $entity3
      ->save();
    $definition = [
      'type' => 'entity:entity_test',
      'bundle' => [
        'foo',
        'bar',
      ],
    ];

    // An entity whose bundle is in the definition list is converted.
    $converted = $converter
      ->convert($entity1
      ->id(), $definition, 'qux', []);
    $this
      ->assertSame($entity1
      ->id(), $converted
      ->id());

    // An entity whose bundle is in the definition list is converted.
    $converted = $converter
      ->convert($entity2
      ->id(), $definition, 'qux', []);
    $this
      ->assertSame($entity2
      ->id(), $converted
      ->id());

    // An entity whose bundle is missed from definition is not converted.
    $converted = $converter
      ->convert($entity3
      ->id(), $definition, 'qux', []);
    $this
      ->assertNull($converted);

    // A non-existing entity returns NULL.
    $converted = $converter
      ->convert('some-non-existing-entity-id', $definition, 'qux', []);
    $this
      ->assertNull($converted);
    $definition = [
      'type' => 'entity:entity_test',
    ];

    // Check that all entities are returned when 'bundle' is not defined.
    $converted = $converter
      ->convert($entity1
      ->id(), $definition, 'qux', []);
    $this
      ->assertSame($entity1
      ->id(), $converted
      ->id());
    $converted = $converter
      ->convert($entity2
      ->id(), $definition, 'qux', []);
    $this
      ->assertSame($entity2
      ->id(), $converted
      ->id());
    $converted = $converter
      ->convert($entity3
      ->id(), $definition, 'qux', []);
    $this
      ->assertSame($entity3
      ->id(), $converted
      ->id());
    $converted = $converter
      ->convert('some-non-existing-entity-id', $definition, 'qux', []);
    $this
      ->assertNull($converted);
  }

}

Members