class RoutingFixtures in Zircon Profile 8
Same name and namespace in other branches
- 8.0 core/tests/Drupal/Tests/Core/Routing/RoutingFixtures.php \Drupal\Tests\Core\Routing\RoutingFixtures
Utility methods to generate sample data, database configuration, etc.
Hierarchy
- class \Drupal\Tests\Core\Routing\RoutingFixtures
Expanded class hierarchy of RoutingFixtures
3 files declare their use of RoutingFixtures
- AcceptHeaderMatcherTest.php in core/
modules/ system/ tests/ modules/ accept_header_routing_test/ tests/ Unit/ AcceptHeaderMatcherTest.php - Contains \Drupal\Tests\accept_header_routing_teste\Unit\Routing\AcceptHeaderMatcherTest.
- MatcherDumperTest.php in core/
modules/ system/ src/ Tests/ Routing/ MatcherDumperTest.php - Contains \Drupal\system\Tests\Routing\MatcherDumperTest.
- RouteProviderTest.php in core/
modules/ system/ src/ Tests/ Routing/ RouteProviderTest.php - Contains \Drupal\system\Tests\Routing\RouteProviderTest.
File
- core/
tests/ Drupal/ Tests/ Core/ Routing/ RoutingFixtures.php, line 18 - Contains \Drupal\Tests\Core\Routing\RoutingFixtures.
Namespace
Drupal\Tests\Core\RoutingView source
class RoutingFixtures {
/**
* Create the tables required for the sample data.
*
* @param \Drupal\Core\Database\Connection $connection
* The connection to use to create the tables.
*/
public function createTables(Connection $connection) {
$tables = $this
->routingTableDefinition();
$schema = $connection
->schema();
foreach ($tables as $name => $table) {
$schema
->dropTable($name);
$schema
->createTable($name, $table);
}
}
/**
* Drop the tables used for the sample data.
*
* @param \Drupal\Core\Database\Connection $connection
* The connection to use to drop the tables.
*/
public function dropTables(Connection $connection) {
$tables = $this
->routingTableDefinition();
$schema = $connection
->schema();
foreach ($tables as $name => $table) {
$schema
->dropTable($name);
}
}
/**
* Returns a static version of the routes.
*/
public function staticSampleRouteCollection() {
$routes = array();
$routes['route_a'] = array(
'path' => '/path/one',
'methods' => array(
'GET',
),
);
$routes['route_b'] = array(
'path' => '/path/one',
'methods' => array(
'PUT',
),
);
$routes['route_c'] = array(
'path' => '/path/two',
'methods' => array(
'GET',
),
'requirements' => array(
'_format' => 'json',
),
);
$routes['route_d'] = array(
'path' => '/path/three',
);
$routes['route_e'] = array(
'path' => '/path/two',
'methods' => array(
'GET',
'HEAD',
),
'requirements' => array(
'_format' => 'html',
),
);
return $routes;
}
/**
* Returns a standard set of routes for testing.
*
* @return \Symfony\Component\Routing\RouteCollection
*/
public function sampleRouteCollection() {
$collection = new RouteCollection();
$route = new Route('path/one');
$route
->setMethods([
'GET',
]);
$collection
->add('route_a', $route);
$route = new Route('path/one');
$route
->setMethods([
'PUT',
]);
$collection
->add('route_b', $route);
$route = new Route('path/two');
$route
->setMethods([
'GET',
]);
$route
->setRequirement('_format', 'json');
$collection
->add('route_c', $route);
$route = new Route('path/three');
$collection
->add('route_d', $route);
$route = new Route('path/two');
$route
->setMethods([
'GET',
'HEAD',
]);
$route
->setRequirement('_format', 'html');
$collection
->add('route_e', $route);
return $collection;
}
/**
* Returns a complex set of routes for testing.
*
* @return \Symfony\Component\Routing\RouteCollection
*/
public function complexRouteCollection() {
$collection = new RouteCollection();
$route = new Route('/path/{thing}/one');
$route
->setMethods([
'GET',
]);
$collection
->add('route_a', $route);
$route = new Route('/path/{thing}/one');
$route
->setMethods([
'PUT',
]);
$collection
->add('route_b', $route);
$route = new Route('/somewhere/{item}/over/the/rainbow');
$route
->setMethods([
'GET',
]);
$collection
->add('route_c', $route);
$route = new Route('/another/{thing}/about/{item}');
$collection
->add('route_d', $route);
$route = new Route('/path/add/one');
$route
->setMethods([
'GET',
'HEAD',
]);
$collection
->add('route_e', $route);
return $collection;
}
/**
* Returns a Content-type restricted set of routes for testing.
*
* @return \Symfony\Component\Routing\RouteCollection
*/
public function contentRouteCollection() {
$collection = new RouteCollection();
$route = new Route('path/three');
$route
->setMethods([
'POST',
]);
$route
->setRequirement('_content_type_format', 'json');
$collection
->add('route_f', $route);
$route = new Route('path/three');
$route
->setMethods([
'PATCH',
]);
$route
->setRequirement('_content_type_format', 'xml');
$collection
->add('route_g', $route);
return $collection;
}
/**
* Returns the table definition for the routing fixtures.
*
* @return array
* Table definitions.
*/
public function routingTableDefinition() {
$tables['test_routes'] = array(
'description' => 'Maps paths to various callbacks (access, page and title)',
'fields' => array(
'name' => array(
'description' => 'Primary Key: Machine name of this route',
'type' => 'varchar_ascii',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'path' => array(
'description' => 'The path for this URI',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'pattern_outline' => array(
'description' => 'The pattern',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'provider' => array(
'description' => 'The provider grouping to which a route belongs.',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'access_callback' => array(
'description' => 'The callback which determines the access to this router path. Defaults to \\Drupal\\Core\\Session\\AccountInterface::hasPermission.',
'type' => 'varchar',
'length' => 255,
'not null' => TRUE,
'default' => '',
),
'access_arguments' => array(
'description' => 'A serialized array of arguments for the access callback.',
'type' => 'blob',
'not null' => FALSE,
),
'fit' => array(
'description' => 'A numeric representation of how specific the path is.',
'type' => 'int',
'not null' => TRUE,
'default' => 0,
),
'number_parts' => array(
'description' => 'Number of parts in this router path.',
'type' => 'int',
'not null' => TRUE,
'default' => 0,
'size' => 'small',
),
'route' => array(
'description' => 'A serialized Route object',
'type' => 'text',
),
),
'indexes' => array(
'fit' => array(
'fit',
),
'pattern_outline' => array(
'pattern_outline',
),
'provider' => array(
'provider',
),
),
'primary key' => array(
'name',
),
);
return $tables;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
RoutingFixtures:: |
public | function | Returns a complex set of routes for testing. | |
RoutingFixtures:: |
public | function | Returns a Content-type restricted set of routes for testing. | |
RoutingFixtures:: |
public | function | Create the tables required for the sample data. | |
RoutingFixtures:: |
public | function | Drop the tables used for the sample data. | |
RoutingFixtures:: |
public | function | Returns the table definition for the routing fixtures. | |
RoutingFixtures:: |
public | function | Returns a standard set of routes for testing. | |
RoutingFixtures:: |
public | function | Returns a static version of the routes. |