You are here

class PathPluginBaseTest in Drupal 10

Same name and namespace in other branches
  1. 8 core/modules/views/tests/src/Unit/Plugin/display/PathPluginBaseTest.php \Drupal\Tests\views\Unit\Plugin\display\PathPluginBaseTest
  2. 9 core/modules/views/tests/src/Unit/Plugin/display/PathPluginBaseTest.php \Drupal\Tests\views\Unit\Plugin\display\PathPluginBaseTest

@coversDefaultClass \Drupal\views\Plugin\views\display\PathPluginBase @group views

Hierarchy

  • class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses \Drupal\Tests\PhpUnitCompatibilityTrait, \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait, PhpUnitWarnings

Expanded class hierarchy of PathPluginBaseTest

File

core/modules/views/tests/src/Unit/Plugin/display/PathPluginBaseTest.php, line 19
Contains \Drupal\Tests\views\Unit\Plugin\display\PathPluginBaseTest.

Namespace

Drupal\Tests\views\Unit\Plugin\display
View source
class PathPluginBaseTest extends UnitTestCase {

  /**
   * The route provider that should be used.
   *
   * @var \Drupal\Core\Routing\RouteProviderInterface|\PHPUnit\Framework\MockObject\MockObject
   */
  protected $routeProvider;

  /**
   * The tested path plugin base.
   *
   * @var \Drupal\views\Plugin\views\display\PathPluginBase|\PHPUnit\Framework\MockObject\MockObject
   */
  protected $pathPlugin;

  /**
   * The mocked views access plugin manager.
   *
   * @var \Drupal\views\Plugin\ViewsPluginManager|\PHPUnit\Framework\MockObject\MockObject
   */
  protected $accessPluginManager;

  /**
   * The mocked key value storage.
   *
   * @var \Drupal\Core\State\StateInterface|\PHPUnit\Framework\MockObject\MockObject
   */
  protected $state;

  /**
   * {@inheritdoc}
   */
  protected function setUp() : void {
    parent::setUp();
    $this->routeProvider = $this
      ->createMock('Drupal\\Core\\Routing\\RouteProviderInterface');
    $this->state = $this
      ->createMock('\\Drupal\\Core\\State\\StateInterface');
    $this->pathPlugin = $this
      ->getMockBuilder('Drupal\\views\\Plugin\\views\\display\\PathPluginBase')
      ->setConstructorArgs([
      [],
      'path_base',
      [],
      $this->routeProvider,
      $this->state,
    ])
      ->onlyMethods([])
      ->getMock();
    $this
      ->setupContainer();
  }

  /**
   * Setup access plugin manager and config factory in the Drupal class.
   */
  public function setupContainer() {
    $this->accessPluginManager = $this
      ->getMockBuilder('\\Drupal\\views\\Plugin\\ViewsPluginManager')
      ->disableOriginalConstructor()
      ->getMock();
    $container = new ContainerBuilder();
    $container
      ->set('plugin.manager.views.access', $this->accessPluginManager);
    $config = [
      'views.settings' => [
        'skip_cache' => TRUE,
        'display_extenders' => [],
      ],
    ];
    $container
      ->set('config.factory', $this
      ->getConfigFactoryStub($config));
    \Drupal::setContainer($container);
  }

  /**
   * Tests the collectRoutes method.
   *
   * @see \Drupal\views\Plugin\views\display\PathPluginBase::collectRoutes()
   */
  public function testCollectRoutes() {
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $collection = new RouteCollection();
    $result = $this->pathPlugin
      ->collectRoutes($collection);
    $this
      ->assertEquals([
      'test_id.page_1' => 'view.test_id.page_1',
    ], $result);
    $route = $collection
      ->get('view.test_id.page_1');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));
    $this
      ->assertFalse($route
      ->getOption('returns_response'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
  }

  /**
   * Tests the collectRoutes method with a display returning a response.
   *
   * @see \Drupal\views\Plugin\views\display\PathPluginBase::collectRoutes()
   */
  public function testCollectRoutesWithDisplayReturnResponse() {
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route',
    ];
    $this->pathPlugin = $this
      ->getMockBuilder('Drupal\\views\\Plugin\\views\\display\\PathPluginBase')
      ->setConstructorArgs([
      [],
      'path_base',
      [
        'returns_response' => TRUE,
      ],
      $this->routeProvider,
      $this->state,
    ])
      ->onlyMethods([])
      ->getMock();
    $this->pathPlugin
      ->initDisplay($view, $display);
    $collection = new RouteCollection();
    $this->pathPlugin
      ->collectRoutes($collection);
    $route = $collection
      ->get('view.test_id.page_1');
    $this
      ->assertTrue($route
      ->getOption('returns_response'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
  }

  /**
   * Tests the collectRoutes method with arguments.
   *
   * @see \Drupal\views\Plugin\views\display\PathPluginBase::collectRoutes()
   */
  public function testCollectRoutesWithArguments() {
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route/%/example',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $collection = new RouteCollection();
    $result = $this->pathPlugin
      ->collectRoutes($collection);
    $this
      ->assertEquals([
      'test_id.page_1' => 'view.test_id.page_1',
    ], $result);
    $route = $collection
      ->get('view.test_id.page_1');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));
    $this
      ->assertEquals([
      'arg_0' => 'arg_0',
    ], $route
      ->getOption('_view_argument_map'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
  }

  /**
   * Tests the collectRoutes method with arguments not specified in the path.
   *
   * @see \Drupal\views\Plugin\views\display\PathPluginBase::collectRoutes()
   */
  public function testCollectRoutesWithArgumentsNotSpecifiedInPath() {
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_with_arguments',
    ];
    $display['display_options']['arguments'] = [
      'test_id' => [],
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $collection = new RouteCollection();
    $result = $this->pathPlugin
      ->collectRoutes($collection);
    $this
      ->assertEquals([
      'test_id.page_1' => 'view.test_id.page_1',
    ], $result);
    $route = $collection
      ->get('view.test_id.page_1');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));
    $this
      ->assertEquals([
      'arg_0' => 'arg_0',
    ], $route
      ->getOption('_view_argument_map'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
  }

  /**
   * Tests the collect routes method with an alternative route name in the UI.
   */
  public function testCollectRoutesWithSpecialRouteName() {
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route',
      'route_name' => 'test_route',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $collection = new RouteCollection();
    $result = $this->pathPlugin
      ->collectRoutes($collection);
    $this
      ->assertEquals([
      'test_id.page_1' => 'test_route',
    ], $result);
    $route = $collection
      ->get('test_route');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
  }

  /**
   * Tests the alter route method.
   */
  public function testAlterRoute() {
    $collection = new RouteCollection();
    $collection
      ->add('test_route', new Route('test_route', [
      '_controller' => 'Drupal\\Tests\\Core\\Controller\\TestController::content',
    ]));
    $route_2 = new Route('test_route/example', [
      '_controller' => 'Drupal\\Tests\\Core\\Controller\\TestController::content',
    ]);
    $collection
      ->add('test_route_2', $route_2);
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $view_route_names = $this->pathPlugin
      ->alterRoutes($collection);
    $this
      ->assertEquals([
      'test_id.page_1' => 'test_route',
    ], $view_route_names);

    // Ensure that the test_route is overridden.
    $route = $collection
      ->get('test_route');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));

    // Ensure that the test_route_2 is not overridden.
    $route = $collection
      ->get('test_route_2');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertFalse($route
      ->hasDefault('view_id'));
    $this
      ->assertFalse($route
      ->hasDefault('display_id'));
    $this
      ->assertSame($collection
      ->get('test_route_2'), $route_2);
  }

  /**
   * Tests the altering of a REST route.
   */
  public function testAlterPostRestRoute() {
    $collection = new RouteCollection();
    $route = new Route('test_route', [
      '_controller' => 'Drupal\\Tests\\Core\\Controller\\TestController::content',
    ]);
    $route
      ->setMethods([
      'POST',
    ]);
    $collection
      ->add('test_route', $route);
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $this->pathPlugin
      ->collectRoutes($collection);
    $view_route_names = $this->pathPlugin
      ->alterRoutes($collection);
    $this
      ->assertEquals([], $view_route_names);

    // Ensure that the test_route is not overridden.
    $this
      ->assertCount(2, $collection);
    $route = $collection
      ->get('test_route');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertFalse($route
      ->hasDefault('view_id'));
    $this
      ->assertFalse($route
      ->hasDefault('display_id'));
    $this
      ->assertSame($collection
      ->get('test_route'), $route);
    $route = $collection
      ->get('view.test_id.page_1');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
  }

  /**
   * Tests the altering of a REST route.
   */
  public function testGetRestRoute() {
    $collection = new RouteCollection();
    $route = new Route('test_route', [
      '_controller' => 'Drupal\\Tests\\Core\\Controller\\TestController::content',
    ]);
    $route
      ->setMethods([
      'GET',
    ]);
    $route
      ->setRequirement('_format', 'json');
    $collection
      ->add('test_route', $route);
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $this->pathPlugin
      ->collectRoutes($collection);
    $view_route_names = $this->pathPlugin
      ->alterRoutes($collection);
    $this
      ->assertEquals([], $view_route_names);

    // Ensure that the test_route is not overridden.
    $this
      ->assertCount(2, $collection);
    $route = $collection
      ->get('test_route');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertFalse($route
      ->hasDefault('view_id'));
    $this
      ->assertFalse($route
      ->hasDefault('display_id'));
    $this
      ->assertSame($collection
      ->get('test_route'), $route);
    $route = $collection
      ->get('view.test_id.page_1');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
  }

  /**
   * Tests the alter route method with preexisting title callback.
   */
  public function testAlterRouteWithAlterCallback() {
    $collection = new RouteCollection();
    $collection
      ->add('test_route', new Route('test_route', [
      '_controller' => 'Drupal\\Tests\\Core\\Controller\\TestController::content',
      '_title_callback' => '\\Drupal\\Tests\\views\\Unit\\Plugin\\display\\TestController::testTitle',
    ]));
    $route_2 = new Route('test_route/example', [
      '_controller' => 'Drupal\\Tests\\Core\\Controller\\TestController::content',
    ]);
    $collection
      ->add('test_route_2', $route_2);
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $view_route_names = $this->pathPlugin
      ->alterRoutes($collection);
    $this
      ->assertEquals([
      'test_id.page_1' => 'test_route',
    ], $view_route_names);

    // Ensure that the test_route is overridden.
    $route = $collection
      ->get('test_route');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('\\Drupal\\Tests\\views\\Unit\\Plugin\\display\\TestController::testTitle', $route
      ->getDefault('_title_callback'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));

    // Ensure that the test_route_2 is not overridden.
    $route = $collection
      ->get('test_route_2');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertFalse($route
      ->hasDefault('view_id'));
    $this
      ->assertFalse($route
      ->hasDefault('display_id'));
    $this
      ->assertSame($collection
      ->get('test_route_2'), $route_2);
  }

  /**
   * Tests the collectRoutes method with a path containing named parameters.
   *
   * @see \Drupal\views\Plugin\views\display\PathPluginBase::collectRoutes()
   */
  public function testCollectRoutesWithNamedParameters() {

    /** @var \Drupal\views\ViewExecutable|\PHPUnit\Framework\MockObject\MockObject $view */
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $view->argument = [];
    $view->argument['nid'] = $this
      ->getMockBuilder('Drupal\\views\\Plugin\\views\\argument\\ArgumentPluginBase')
      ->disableOriginalConstructor()
      ->getMock();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route/%node/example',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $collection = new RouteCollection();
    $result = $this->pathPlugin
      ->collectRoutes($collection);
    $this
      ->assertEquals([
      'test_id.page_1' => 'view.test_id.page_1',
    ], $result);
    $route = $collection
      ->get('view.test_id.page_1');
    $this
      ->assertInstanceOf(Route::class, $route);
    $this
      ->assertEquals('/test_route/{node}/example', $route
      ->getPath());
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
    $this
      ->assertEquals([
      'arg_0' => 'node',
    ], $route
      ->getOption('_view_argument_map'));
  }

  /**
   * Tests altering routes with parameters in the overridden route.
   */
  public function testAlterRoutesWithParameters() {
    $collection = new RouteCollection();
    $collection
      ->add('test_route', new Route('test_route/{parameter}', [
      '_controller' => 'Drupal\\Tests\\Core\\Controller\\TestController::content',
    ]));
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();

    // Manually set up an argument handler.
    $argument = $this
      ->getMockBuilder('Drupal\\views\\Plugin\\views\\argument\\ArgumentPluginBase')
      ->disableOriginalConstructor()
      ->getMock();
    $view->argument['test_id'] = $argument;
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route/%',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $view_route_names = $this->pathPlugin
      ->alterRoutes($collection);
    $this
      ->assertEquals([
      'test_id.page_1' => 'test_route',
    ], $view_route_names);

    // Ensure that the test_route is overridden.
    $route = $collection
      ->get('test_route');
    $this
      ->assertInstanceOf('\\Symfony\\Component\\Routing\\Route', $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));

    // Ensure that the path did not changed and placeholders are respected.
    $this
      ->assertEquals('/test_route/{parameter}', $route
      ->getPath());
    $this
      ->assertEquals([
      'arg_0' => 'parameter',
    ], $route
      ->getOption('_view_argument_map'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
  }

  /**
   * Tests altering routes with parameters and upcasting information.
   */
  public function testAlterRoutesWithParametersAndUpcasting() {
    $collection = new RouteCollection();
    $collection
      ->add('test_route', new Route('test_route/{parameter}', [
      '_controller' => 'Drupal\\Tests\\Core\\Controller\\TestController::content',
    ], [], [
      'parameters' => [
        'taxonomy_term' => 'entity:entity_test',
      ],
    ]));
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();

    // Manually set up an argument handler.
    $argument = $this
      ->getMockBuilder('Drupal\\views\\Plugin\\views\\argument\\ArgumentPluginBase')
      ->disableOriginalConstructor()
      ->getMock();
    $view->argument['test_id'] = $argument;
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route/%',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $view_route_names = $this->pathPlugin
      ->alterRoutes($collection);
    $this
      ->assertEquals([
      'test_id.page_1' => 'test_route',
    ], $view_route_names);

    // Ensure that the test_route is overridden.
    $route = $collection
      ->get('test_route');
    $this
      ->assertInstanceOf('\\Symfony\\Component\\Routing\\Route', $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));
    $this
      ->assertEquals([
      'taxonomy_term' => 'entity:entity_test',
    ], $route
      ->getOption('parameters'));

    // Ensure that the path did not changed and placeholders are respected  kk.
    $this
      ->assertEquals('/test_route/{parameter}', $route
      ->getPath());
    $this
      ->assertEquals([
      'arg_0' => 'parameter',
    ], $route
      ->getOption('_view_argument_map'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
  }

  /**
   * Tests altering routes with optional parameters in the overridden route.
   */
  public function testAlterRoutesWithOptionalParameters() {
    $collection = new RouteCollection();
    $collection
      ->add('test_route', new Route('test_route/{parameter}', [
      '_controller' => 'Drupal\\Tests\\Core\\Controller\\TestController::content',
    ]));
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route/%',
    ];
    $display['display_options']['arguments'] = [
      'test_id' => [],
      'test_id2' => [],
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $view_route_names = $this->pathPlugin
      ->alterRoutes($collection);
    $this
      ->assertEquals([
      'test_id.page_1' => 'test_route',
    ], $view_route_names);

    // Ensure that the test_route is overridden.
    $route = $collection
      ->get('test_route');
    $this
      ->assertInstanceOf('\\Symfony\\Component\\Routing\\Route', $route);
    $this
      ->assertEquals('test_id', $route
      ->getDefault('view_id'));
    $this
      ->assertEquals('page_1', $route
      ->getDefault('display_id'));

    // Ensure that the path did not changed and placeholders are respected.
    $this
      ->assertEquals('/test_route/{parameter}/{arg_1}', $route
      ->getPath());
    $this
      ->assertEquals([
      'arg_0' => 'parameter',
    ], $route
      ->getOption('_view_argument_map'));
    $this
      ->assertEquals('Drupal\\views\\Routing\\ViewPageController::getTitle', $route
      ->getDefault('_title_callback'));
  }

  /**
   * Tests the getRouteName method.
   */
  public function testGetRouteName() {
    [
      $view,
    ] = $this
      ->setupViewExecutableAccessPlugin();
    $display = [];
    $display['display_plugin'] = 'page';
    $display['id'] = 'page_1';
    $display['display_options'] = [
      'path' => 'test_route',
    ];
    $this->pathPlugin
      ->initDisplay($view, $display);
    $route_name = $this->pathPlugin
      ->getRouteName();

    // Ensure that the expected route name is returned.
    $this
      ->assertEquals('view.test_id.page_1', $route_name);
  }

  /**
   * Returns some mocked view entity, view executable, and access plugin.
   */
  protected function setupViewExecutableAccessPlugin() {
    $view_entity = $this
      ->getMockBuilder('Drupal\\views\\Entity\\View')
      ->disableOriginalConstructor()
      ->getMock();
    $view_entity
      ->expects($this
      ->any())
      ->method('id')
      ->will($this
      ->returnValue('test_id'));
    $view = $this
      ->getMockBuilder('Drupal\\views\\ViewExecutable')
      ->disableOriginalConstructor()
      ->getMock();
    $view->storage = $view_entity;

    // Skip views options caching.
    $view->editing = TRUE;
    $access_plugin = $this
      ->getMockBuilder('Drupal\\views\\Plugin\\views\\access\\AccessPluginBase')
      ->disableOriginalConstructor()
      ->getMockForAbstractClass();
    $this->accessPluginManager
      ->expects($this
      ->any())
      ->method('createInstance')
      ->will($this
      ->returnValue($access_plugin));
    return [
      $view,
      $view_entity,
      $access_plugin,
    ];
  }

}

Members

Namesort descending Modifiers Type Description Overrides
PathPluginBaseTest::$accessPluginManager protected property The mocked views access plugin manager.
PathPluginBaseTest::$pathPlugin protected property The tested path plugin base.
PathPluginBaseTest::$routeProvider protected property The route provider that should be used.
PathPluginBaseTest::$state protected property The mocked key value storage.
PathPluginBaseTest::setUp protected function Overrides UnitTestCase::setUp
PathPluginBaseTest::setupContainer public function Setup access plugin manager and config factory in the Drupal class.
PathPluginBaseTest::setupViewExecutableAccessPlugin protected function Returns some mocked view entity, view executable, and access plugin.
PathPluginBaseTest::testAlterPostRestRoute public function Tests the altering of a REST route.
PathPluginBaseTest::testAlterRoute public function Tests the alter route method.
PathPluginBaseTest::testAlterRoutesWithOptionalParameters public function Tests altering routes with optional parameters in the overridden route.
PathPluginBaseTest::testAlterRoutesWithParameters public function Tests altering routes with parameters in the overridden route.
PathPluginBaseTest::testAlterRoutesWithParametersAndUpcasting public function Tests altering routes with parameters and upcasting information.
PathPluginBaseTest::testAlterRouteWithAlterCallback public function Tests the alter route method with preexisting title callback.
PathPluginBaseTest::testCollectRoutes public function Tests the collectRoutes method.
PathPluginBaseTest::testCollectRoutesWithArguments public function Tests the collectRoutes method with arguments.
PathPluginBaseTest::testCollectRoutesWithArgumentsNotSpecifiedInPath public function Tests the collectRoutes method with arguments not specified in the path.
PathPluginBaseTest::testCollectRoutesWithDisplayReturnResponse public function Tests the collectRoutes method with a display returning a response.
PathPluginBaseTest::testCollectRoutesWithNamedParameters public function Tests the collectRoutes method with a path containing named parameters.
PathPluginBaseTest::testCollectRoutesWithSpecialRouteName public function Tests the collect routes method with an alternative route name in the UI.
PathPluginBaseTest::testGetRestRoute public function Tests the altering of a REST route.
PathPluginBaseTest::testGetRouteName public function Tests the getRouteName method.
PhpUnitWarnings::$deprecationWarnings private static property Deprecation warnings from PHPUnit to raise with @trigger_error().
PhpUnitWarnings::addWarning public function Converts PHPUnit deprecation warnings to E_USER_DEPRECATED.
UnitTestCase::$randomGenerator protected property The random generator.
UnitTestCase::$root protected property The app root. 1
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::getConfigStorageStub public function Returns a stub config storage that returns the supplied configuration.
UnitTestCase::getContainerWithCacheTagsInvalidator protected function Sets up a container with a cache tags invalidator.
UnitTestCase::getRandomGenerator protected function Gets the random generator for the utility methods.
UnitTestCase::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::randomMachineName public function Generates a unique random string containing letters and numbers.
UnitTestCase::setUpBeforeClass public static function