class EntityRevisionRouteEnhancerTest

Same name and namespace in other branches
  1. 9 core/tests/Drupal/Tests/Core/Enhancer/EntityRevisionRouteEnhancerTest.php \Drupal\Tests\Core\Enhancer\EntityRevisionRouteEnhancerTest

@coversDefaultClass \Drupal\Core\Routing\Enhancer\EntityRevisionRouteEnhancer
@group Entity

Hierarchy

Expanded class hierarchy of EntityRevisionRouteEnhancerTest

File

core/tests/Drupal/Tests/Core/Enhancer/EntityRevisionRouteEnhancerTest.php, line 18

Namespace

Drupal\Tests\Core\Enhancer
View source
class EntityRevisionRouteEnhancerTest extends UnitTestCase {
  
  /**
   * @var \Drupal\Core\Routing\Enhancer\EntityRevisionRouteEnhancer
   */
  protected $routeEnhancer;
  
  /**
   * {@inheritdoc}
   */
  protected function setUp() : void {
    parent::setUp();
    $this->routeEnhancer = new EntityRevisionRouteEnhancer();
  }
  
  /**
   * @covers ::enhance
   */
  public function testEnhanceWithoutParameter() : void {
    $route = new Route('/test-path/{entity_test}');
    $request = Request::create('/test-path');
    $defaults = [];
    $defaults[RouteObjectInterface::ROUTE_OBJECT] = $route;
    $this->assertEquals($defaults, $this->routeEnhancer
      ->enhance($defaults, $request));
  }
  
  /**
   * @covers ::enhance
   */
  public function testEnhanceWithoutEntityRevision() : void {
    $route = new Route('/test-path/{entity_test}', [], [], [
      'parameters' => [
        'entity_test' => [
          'type' => 'entity:entity_test',
        ],
      ],
    ]);
    $request = Request::create('/test-path/123');
    $entity = $this->prophesize(EntityInterface::class);
    $defaults = [];
    $defaults['entity_test'] = $entity->reveal();
    $defaults[RouteObjectInterface::ROUTE_OBJECT] = $route;
    $this->assertEquals($defaults, $this->routeEnhancer
      ->enhance($defaults, $request));
  }
  
  /**
   * @covers ::enhance
   */
  public function testEnhanceWithEntityRevision() : void {
    $route = new Route('/test-path/{entity_test_revision}', [], [], [
      'parameters' => [
        'entity_test_revision' => [
          'type' => 'entity_revision:entity_test',
        ],
      ],
    ]);
    $request = Request::create('/test-path/123');
    $entity = $this->prophesize(EntityInterface::class);
    $defaults = [];
    $defaults['entity_test_revision'] = $entity->reveal();
    $defaults[RouteObjectInterface::ROUTE_OBJECT] = $route;
    $expected = $defaults;
    $expected['_entity_revision'] = $defaults['entity_test_revision'];
    $this->assertEquals($expected, $this->routeEnhancer
      ->enhance($defaults, $request));
  }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title
EntityRevisionRouteEnhancerTest::$routeEnhancer protected property
EntityRevisionRouteEnhancerTest::setUp protected function Overrides UnitTestCase::setUp
EntityRevisionRouteEnhancerTest::testEnhanceWithEntityRevision public function @covers ::enhance[[api-linebreak]]
EntityRevisionRouteEnhancerTest::testEnhanceWithoutEntityRevision public function @covers ::enhance[[api-linebreak]]
EntityRevisionRouteEnhancerTest::testEnhanceWithoutParameter public function @covers ::enhance[[api-linebreak]]
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.
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::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.