class ModernRenderElementTest

@coversDefaultClass \Drupal\Core\Render\Element\RenderElementBase
@group Render

Hierarchy

Expanded class hierarchy of ModernRenderElementTest

File

core/tests/Drupal/Tests/Core/Render/Element/ModernRenderElementTest.php, line 17

Namespace

Drupal\Tests\Core\Render\Element
View source
class ModernRenderElementTest extends UnitTestCase {
  public function testChildren() : void {
    $factory = $this->createMock(FactoryInterface::class);
    $elementInfoManager = new class ($factory) extends ElementInfoManager {
      public function __construct(protected $factory) {
      }

};
    $factory->expects($this->any())
      ->method('createInstance')
      ->willReturnCallback(fn() => new Textfield([], '', NULL, $elementInfoManager));
    // If the type is not given ::fromRenderable presumes "form" and uses the
    // plugin discovery to find which class provides the form element. This
    // test does not set up discovery so some type must be provided.
    $element = [
      '#type' => 'ignored by the mock factory',
    ];
    $elementObject = $elementInfoManager->fromRenderable($element);
    for ($i = 0; $i <= 2; $i++) {
      $child = [
        '#type' => 'ignored by the mock factory',
        '#test' => $i,
      ];
      $elementObject->addChild("test{$i}", $child);
      // addChild() takes the $child render array by reference and stores a
      // reference to it in the render object. To avoid modifying the
      // previously created render object when reusing the $child variable,
      // unset() it to break the reference before reassigning.
      unset($child);
    }
    foreach ([
      1 => [
        'test0',
        'test1',
        'test2',
      ],
      2 => [
        'test0',
        'test2',
      ],
    ] as $delta => $expectedChildrenKeys) {
      $i = 0;
      foreach ($elementObject->getChildren() as $name => $child) {
        $this->assertSame($name, "test{$i}");
        $this->assertSame($i, $child->test);
        $i += $delta;
      }
      $this->assertSame(Element::children($elementObject->toRenderable()), $expectedChildrenKeys);
      // The first iteration tests removing an existing child. The second
      // iteration tests removing a nonexistent child.
      $elementObject->removeChild('test1');
    }
  }

}

Members

Title Sort descending Modifiers Object type Summary Overrides
ExpectDeprecationTrait::expectDeprecation public function Adds an expected deprecation.
ExpectDeprecationTrait::setUpErrorHandler public function Sets up the test error handler.
ExpectDeprecationTrait::tearDownErrorHandler public function Tears down the test error handler.
ModernRenderElementTest::testChildren public function
RandomGeneratorTrait::getRandomGenerator protected function Gets the random generator for the utility methods.
RandomGeneratorTrait::randomMachineName protected function Generates a unique random string containing letters and numbers.
RandomGeneratorTrait::randomObject public function Generates a random PHP object.
RandomGeneratorTrait::randomString public function Generates a pseudo-random string of ASCII characters of codes 32 to 126.
UnitTestCase::$root protected property The app root.
UnitTestCase::getClassResolverStub protected function Returns a stub class resolver.
UnitTestCase::getConfigFactoryStub public function Returns a stub config factory that behaves according to the passed array.
UnitTestCase::getContainerWithCacheTagsInvalidator protected function Sets up a container with a cache tags invalidator.
UnitTestCase::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::setDebugDumpHandler public static function Registers the dumper CLI handler when the DebugDump extension is enabled.
UnitTestCase::setUp protected function 375
UnitTestCase::setupMockIterator protected function Set up a traversable class mock to return specific items when iterated.

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