class RouteBuilderTest in Drupal 8
@coversDefaultClass \Drupal\Core\Routing\RouteBuilder @group Routing
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses PhpunitCompatibilityTrait
- class \Drupal\Tests\Core\Routing\RouteBuilderTest
Expanded class hierarchy of RouteBuilderTest
File
- core/
tests/ Drupal/ Tests/ Core/ Routing/ RouteBuilderTest.php, line 24 - Contains \Drupal\Tests\Core\Routing\RouteBuilderTest.
Namespace
Drupal\Tests\Core\RoutingView source
class RouteBuilderTest extends UnitTestCase {
/**
* The actual tested route builder.
*
* @var \Drupal\Core\Routing\RouteBuilder
*/
protected $routeBuilder;
/**
* The mocked matcher dumper.
*
* @var \Drupal\Core\Routing\MatcherDumperInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $dumper;
/**
* The mocked lock backend.
*
* @var \Drupal\Core\Lock\LockBackendInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $lock;
/**
* The mocked event dispatcher.
*
* @var \Symfony\Component\EventDispatcher\EventDispatcherInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $dispatcher;
/**
* The mocked YAML discovery.
*
* @var \Drupal\Core\Discovery\YamlDiscovery|\PHPUnit\Framework\MockObject\MockObject
*/
protected $yamlDiscovery;
/**
* The module handler.
*
* @var \Drupal\Core\Extension\ModuleHandlerInterface
*/
protected $moduleHandler;
/**
* The controller resolver.
*
* @var \Drupal\Core\Controller\ControllerResolverInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $controllerResolver;
/**
* @var \Drupal\Core\Access\CheckProviderInterface|\PHPUnit\Framework\MockObject\MockObject
*/
protected $checkProvider;
protected function setUp() {
$this->dumper = $this
->createMock('Drupal\\Core\\Routing\\MatcherDumperInterface');
$this->lock = $this
->createMock('Drupal\\Core\\Lock\\LockBackendInterface');
$this->dispatcher = $this
->createMock('\\Symfony\\Component\\EventDispatcher\\EventDispatcherInterface');
$this->moduleHandler = $this
->createMock('Drupal\\Core\\Extension\\ModuleHandlerInterface');
$this->controllerResolver = $this
->createMock('Drupal\\Core\\Controller\\ControllerResolverInterface');
$this->yamlDiscovery = $this
->getMockBuilder('\\Drupal\\Core\\Discovery\\YamlDiscovery')
->disableOriginalConstructor()
->getMock();
$this->checkProvider = $this
->createMock('\\Drupal\\Core\\Access\\CheckProviderInterface');
$this->routeBuilder = new TestRouteBuilder($this->dumper, $this->lock, $this->dispatcher, $this->moduleHandler, $this->controllerResolver, $this->checkProvider);
$this->routeBuilder
->setYamlDiscovery($this->yamlDiscovery);
}
/**
* Tests that the route rebuilding both locks and unlocks.
*/
public function testRebuildLockingUnlocking() {
$this->lock
->expects($this
->once())
->method('acquire')
->with('router_rebuild')
->will($this
->returnValue(TRUE));
$this->lock
->expects($this
->once())
->method('release')
->with('router_rebuild');
$this->yamlDiscovery
->expects($this
->any())
->method('findAll')
->will($this
->returnValue([]));
$this
->assertTrue($this->routeBuilder
->rebuild());
}
/**
* Tests route rebuilding with a blocking lock.
*/
public function testRebuildBlockingLock() {
$this->lock
->expects($this
->once())
->method('acquire')
->with('router_rebuild')
->will($this
->returnValue(FALSE));
$this->lock
->expects($this
->once())
->method('wait')
->with('router_rebuild');
$this->lock
->expects($this
->never())
->method('release');
$this->yamlDiscovery
->expects($this
->never())
->method('findAll');
$this
->assertFalse($this->routeBuilder
->rebuild());
}
/**
* Tests that provided routes by a module is put into the dumper/dispatcher.
*
* @see \Drupal\Core\Routing\RouteBuilder::rebuild()
*/
public function testRebuildWithStaticModuleRoutes() {
$this->lock
->expects($this
->once())
->method('acquire')
->with('router_rebuild')
->will($this
->returnValue(TRUE));
$routing_fixtures = new RoutingFixtures();
$routes = $routing_fixtures
->staticSampleRouteCollection();
$this->yamlDiscovery
->expects($this
->once())
->method('findAll')
->will($this
->returnValue([
'test_module' => $routes,
]));
$route_collection = $routing_fixtures
->sampleRouteCollection();
foreach ($route_collection
->all() as $route) {
$route
->setOption('compiler_class', RouteCompiler::class);
}
$route_build_event = new RouteBuildEvent($route_collection);
// Ensure that the alter routes events are fired.
$this->dispatcher
->expects($this
->at(0))
->method('dispatch')
->with(RoutingEvents::DYNAMIC, $route_build_event);
$this->dispatcher
->expects($this
->at(1))
->method('dispatch')
->with(RoutingEvents::ALTER, $route_build_event);
// Ensure that access checks are set.
$this->checkProvider
->expects($this
->once())
->method('setChecks')
->with($route_collection);
// Ensure that the routes are set to the dumper and dumped.
$this->dumper
->expects($this
->at(0))
->method('addRoutes')
->with($route_collection);
$this->dumper
->expects($this
->at(1))
->method('dump')
->with();
$this
->assertTrue($this->routeBuilder
->rebuild());
}
/**
* Tests the rebuild with routes provided by a callback.
*
* @see \Drupal\Core\Routing\RouteBuilder::rebuild()
*/
public function testRebuildWithProviderBasedRoutes() {
$this->lock
->expects($this
->once())
->method('acquire')
->with('router_rebuild')
->will($this
->returnValue(TRUE));
$this->yamlDiscovery
->expects($this
->once())
->method('findAll')
->will($this
->returnValue([
'test_module' => [
'route_callbacks' => [
'\\Drupal\\Tests\\Core\\Routing\\TestRouteSubscriber::routesFromArray',
'test_module.route_service:routesFromCollection',
],
],
]));
$container = new ContainerBuilder();
$container
->set('test_module.route_service', new TestRouteSubscriber());
$this->controllerResolver
->expects($this
->any())
->method('getControllerFromDefinition')
->will($this
->returnCallback(function ($controller) use ($container) {
$count = substr_count($controller, ':');
if ($count == 1) {
list($service, $method) = explode(':', $controller, 2);
$object = $container
->get($service);
}
else {
list($class, $method) = explode('::', $controller, 2);
$object = new $class();
}
return [
$object,
$method,
];
}));
$route_collection_filled = new RouteCollection();
$route_collection_filled
->add('test_route.1', new Route('/test-route/1'));
$route_collection_filled
->add('test_route.2', new Route('/test-route/2'));
$route_build_event = new RouteBuildEvent($route_collection_filled);
// Ensure that the alter routes events are fired.
$this->dispatcher
->expects($this
->at(0))
->method('dispatch')
->with(RoutingEvents::DYNAMIC, $route_build_event);
$this->dispatcher
->expects($this
->at(1))
->method('dispatch')
->with(RoutingEvents::ALTER, $route_build_event);
// Ensure that access checks are set.
$this->checkProvider
->expects($this
->once())
->method('setChecks')
->with($route_collection_filled);
// Ensure that the routes are set to the dumper and dumped.
$this->dumper
->expects($this
->at(0))
->method('addRoutes')
->with($route_collection_filled);
$this->dumper
->expects($this
->at(1))
->method('dump');
$this
->assertTrue($this->routeBuilder
->rebuild());
}
/**
* Tests \Drupal\Core\Routing\RouteBuilder::rebuildIfNeeded() method.
*/
public function testRebuildIfNeeded() {
$this->lock
->expects($this
->once())
->method('acquire')
->with('router_rebuild')
->will($this
->returnValue(TRUE));
$this->lock
->expects($this
->once())
->method('release')
->with('router_rebuild');
$this->yamlDiscovery
->expects($this
->any())
->method('findAll')
->will($this
->returnValue([]));
$this->routeBuilder
->setRebuildNeeded();
// This will trigger a successful rebuild.
$this
->assertTrue($this->routeBuilder
->rebuildIfNeeded());
// This will not trigger a rebuild.
$this
->assertFalse($this->routeBuilder
->rebuildIfNeeded());
}
/**
* Tests routes can use alternative compiler classes.
*
* @see \Drupal\Core\Routing\RouteBuilder::rebuild()
*/
public function testRebuildWithOverriddenRouteClass() {
$this->lock
->expects($this
->once())
->method('acquire')
->with('router_rebuild')
->will($this
->returnValue(TRUE));
$this->yamlDiscovery
->expects($this
->once())
->method('findAll')
->will($this
->returnValue([
'test_module' => [
'test_route.override' => [
'path' => '/test_route_override',
'options' => [
'compiler_class' => 'Class\\Does\\Not\\Exist',
],
],
'test_route' => [
'path' => '/test_route',
],
],
]));
$container = new ContainerBuilder();
$container
->set('test_module.route_service', new TestRouteSubscriber());
// Test that routes can have alternative compiler classes.
$route_collection_filled = new RouteCollection();
$route_collection_filled
->add('test_route.override', new Route('/test_route_override', [], [], [
'compiler_class' => 'Class\\Does\\Not\\Exist',
]));
$route_collection_filled
->add('test_route', new Route('/test_route', [], [], [
'compiler_class' => RouteCompiler::class,
]));
$route_build_event = new RouteBuildEvent($route_collection_filled);
$this->dispatcher
->expects($this
->at(0))
->method('dispatch')
->with(RoutingEvents::DYNAMIC, $route_build_event);
$this
->assertTrue($this->routeBuilder
->rebuild());
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
PhpunitCompatibilityTrait:: |
public | function | Returns a mock object for the specified class using the available method. | |
PhpunitCompatibilityTrait:: |
public | function | Compatibility layer for PHPUnit 6 to support PHPUnit 4 code. | |
RouteBuilderTest:: |
protected | property | ||
RouteBuilderTest:: |
protected | property | The controller resolver. | |
RouteBuilderTest:: |
protected | property | The mocked event dispatcher. | |
RouteBuilderTest:: |
protected | property | The mocked matcher dumper. | |
RouteBuilderTest:: |
protected | property | The mocked lock backend. | |
RouteBuilderTest:: |
protected | property | The module handler. | |
RouteBuilderTest:: |
protected | property | The actual tested route builder. | |
RouteBuilderTest:: |
protected | property | The mocked YAML discovery. | |
RouteBuilderTest:: |
protected | function |
Overrides UnitTestCase:: |
|
RouteBuilderTest:: |
public | function | Tests route rebuilding with a blocking lock. | |
RouteBuilderTest:: |
public | function | Tests \Drupal\Core\Routing\RouteBuilder::rebuildIfNeeded() method. | |
RouteBuilderTest:: |
public | function | Tests that the route rebuilding both locks and unlocks. | |
RouteBuilderTest:: |
public | function | Tests routes can use alternative compiler classes. | |
RouteBuilderTest:: |
public | function | Tests the rebuild with routes provided by a callback. | |
RouteBuilderTest:: |
public | function | Tests that provided routes by a module is put into the dumper/dispatcher. | |
UnitTestCase:: |
protected | property | The random generator. | |
UnitTestCase:: |
protected | property | The app root. | 1 |
UnitTestCase:: |
protected | function | Asserts if two arrays are equal by sorting them first. | |
UnitTestCase:: |
protected | function | Mocks a block with a block plugin. | 1 |
UnitTestCase:: |
protected | function | Returns a stub class resolver. | |
UnitTestCase:: |
public | function | Returns a stub config factory that behaves according to the passed array. | |
UnitTestCase:: |
public | function | Returns a stub config storage that returns the supplied configuration. | |
UnitTestCase:: |
protected | function | Sets up a container with a cache tags invalidator. | |
UnitTestCase:: |
protected | function | Gets the random generator for the utility methods. | |
UnitTestCase:: |
public | function | Returns a stub translation manager that just returns the passed string. | |
UnitTestCase:: |
public | function | Generates a unique random string containing letters and numbers. |