class RouteTest in Zircon Profile 8
Same name in this branch
- 8 vendor/symfony/routing/Tests/RouteTest.php \Symfony\Component\Routing\Tests\RouteTest
- 8 vendor/symfony/routing/Tests/Annotation/RouteTest.php \Symfony\Component\Routing\Tests\Annotation\RouteTest
Same name and namespace in other branches
- 8.0 vendor/symfony/routing/Tests/RouteTest.php \Symfony\Component\Routing\Tests\RouteTest
Hierarchy
- class \Symfony\Component\Routing\Tests\RouteTest extends \Symfony\Component\Routing\Tests\PHPUnit_Framework_TestCase
Expanded class hierarchy of RouteTest
File
- vendor/
symfony/ routing/ Tests/ RouteTest.php, line 16
Namespace
Symfony\Component\Routing\TestsView source
class RouteTest extends \PHPUnit_Framework_TestCase {
public function testConstructor() {
$route = new Route('/{foo}', array(
'foo' => 'bar',
), array(
'foo' => '\\d+',
), array(
'foo' => 'bar',
), '{locale}.example.com');
$this
->assertEquals('/{foo}', $route
->getPath(), '__construct() takes a path as its first argument');
$this
->assertEquals(array(
'foo' => 'bar',
), $route
->getDefaults(), '__construct() takes defaults as its second argument');
$this
->assertEquals(array(
'foo' => '\\d+',
), $route
->getRequirements(), '__construct() takes requirements as its third argument');
$this
->assertEquals('bar', $route
->getOption('foo'), '__construct() takes options as its fourth argument');
$this
->assertEquals('{locale}.example.com', $route
->getHost(), '__construct() takes a host pattern as its fifth argument');
$route = new Route('/', array(), array(), array(), '', array(
'Https',
), array(
'POST',
'put',
), 'context.getMethod() == "GET"');
$this
->assertEquals(array(
'https',
), $route
->getSchemes(), '__construct() takes schemes as its sixth argument and lowercases it');
$this
->assertEquals(array(
'POST',
'PUT',
), $route
->getMethods(), '__construct() takes methods as its seventh argument and uppercases it');
$this
->assertEquals('context.getMethod() == "GET"', $route
->getCondition(), '__construct() takes a condition as its eight argument');
$route = new Route('/', array(), array(), array(), '', 'Https', 'Post');
$this
->assertEquals(array(
'https',
), $route
->getSchemes(), '__construct() takes a single scheme as its sixth argument');
$this
->assertEquals(array(
'POST',
), $route
->getMethods(), '__construct() takes a single method as its seventh argument');
}
public function testPath() {
$route = new Route('/{foo}');
$route
->setPath('/{bar}');
$this
->assertEquals('/{bar}', $route
->getPath(), '->setPath() sets the path');
$route
->setPath('');
$this
->assertEquals('/', $route
->getPath(), '->setPath() adds a / at the beginning of the path if needed');
$route
->setPath('bar');
$this
->assertEquals('/bar', $route
->getPath(), '->setPath() adds a / at the beginning of the path if needed');
$this
->assertEquals($route, $route
->setPath(''), '->setPath() implements a fluent interface');
$route
->setPath('//path');
$this
->assertEquals('/path', $route
->getPath(), '->setPath() does not allow two slashes "//" at the beginning of the path as it would be confused with a network path when generating the path from the route');
}
public function testOptions() {
$route = new Route('/{foo}');
$route
->setOptions(array(
'foo' => 'bar',
));
$this
->assertEquals(array_merge(array(
'compiler_class' => 'Symfony\\Component\\Routing\\RouteCompiler',
), array(
'foo' => 'bar',
)), $route
->getOptions(), '->setOptions() sets the options');
$this
->assertEquals($route, $route
->setOptions(array()), '->setOptions() implements a fluent interface');
$route
->setOptions(array(
'foo' => 'foo',
));
$route
->addOptions(array(
'bar' => 'bar',
));
$this
->assertEquals($route, $route
->addOptions(array()), '->addOptions() implements a fluent interface');
$this
->assertEquals(array(
'foo' => 'foo',
'bar' => 'bar',
'compiler_class' => 'Symfony\\Component\\Routing\\RouteCompiler',
), $route
->getOptions(), '->addDefaults() keep previous defaults');
}
public function testOption() {
$route = new Route('/{foo}');
$this
->assertFalse($route
->hasOption('foo'), '->hasOption() return false if option is not set');
$this
->assertEquals($route, $route
->setOption('foo', 'bar'), '->setOption() implements a fluent interface');
$this
->assertEquals('bar', $route
->getOption('foo'), '->setOption() sets the option');
$this
->assertTrue($route
->hasOption('foo'), '->hasOption() return true if option is set');
}
public function testDefaults() {
$route = new Route('/{foo}');
$route
->setDefaults(array(
'foo' => 'bar',
));
$this
->assertEquals(array(
'foo' => 'bar',
), $route
->getDefaults(), '->setDefaults() sets the defaults');
$this
->assertEquals($route, $route
->setDefaults(array()), '->setDefaults() implements a fluent interface');
$route
->setDefault('foo', 'bar');
$this
->assertEquals('bar', $route
->getDefault('foo'), '->setDefault() sets a default value');
$route
->setDefault('foo2', 'bar2');
$this
->assertEquals('bar2', $route
->getDefault('foo2'), '->getDefault() return the default value');
$this
->assertNull($route
->getDefault('not_defined'), '->getDefault() return null if default value is not set');
$route
->setDefault('_controller', $closure = function () {
return 'Hello';
});
$this
->assertEquals($closure, $route
->getDefault('_controller'), '->setDefault() sets a default value');
$route
->setDefaults(array(
'foo' => 'foo',
));
$route
->addDefaults(array(
'bar' => 'bar',
));
$this
->assertEquals($route, $route
->addDefaults(array()), '->addDefaults() implements a fluent interface');
$this
->assertEquals(array(
'foo' => 'foo',
'bar' => 'bar',
), $route
->getDefaults(), '->addDefaults() keep previous defaults');
}
public function testRequirements() {
$route = new Route('/{foo}');
$route
->setRequirements(array(
'foo' => '\\d+',
));
$this
->assertEquals(array(
'foo' => '\\d+',
), $route
->getRequirements(), '->setRequirements() sets the requirements');
$this
->assertEquals('\\d+', $route
->getRequirement('foo'), '->getRequirement() returns a requirement');
$this
->assertNull($route
->getRequirement('bar'), '->getRequirement() returns null if a requirement is not defined');
$route
->setRequirements(array(
'foo' => '^\\d+$',
));
$this
->assertEquals('\\d+', $route
->getRequirement('foo'), '->getRequirement() removes ^ and $ from the path');
$this
->assertEquals($route, $route
->setRequirements(array()), '->setRequirements() implements a fluent interface');
$route
->setRequirements(array(
'foo' => '\\d+',
));
$route
->addRequirements(array(
'bar' => '\\d+',
));
$this
->assertEquals($route, $route
->addRequirements(array()), '->addRequirements() implements a fluent interface');
$this
->assertEquals(array(
'foo' => '\\d+',
'bar' => '\\d+',
), $route
->getRequirements(), '->addRequirement() keep previous requirements');
}
public function testRequirement() {
$route = new Route('/{foo}');
$this
->assertFalse($route
->hasRequirement('foo'), '->hasRequirement() return false if requirement is not set');
$route
->setRequirement('foo', '^\\d+$');
$this
->assertEquals('\\d+', $route
->getRequirement('foo'), '->setRequirement() removes ^ and $ from the path');
$this
->assertTrue($route
->hasRequirement('foo'), '->hasRequirement() return true if requirement is set');
}
/**
* @dataProvider getInvalidRequirements
* @expectedException \InvalidArgumentException
*/
public function testSetInvalidRequirement($req) {
$route = new Route('/{foo}');
$route
->setRequirement('foo', $req);
}
public function getInvalidRequirements() {
return array(
array(
'',
),
array(
array(),
),
array(
'^$',
),
array(
'^',
),
array(
'$',
),
);
}
public function testHost() {
$route = new Route('/');
$route
->setHost('{locale}.example.net');
$this
->assertEquals('{locale}.example.net', $route
->getHost(), '->setHost() sets the host pattern');
}
public function testScheme() {
$route = new Route('/');
$this
->assertEquals(array(), $route
->getSchemes(), 'schemes is initialized with array()');
$this
->assertFalse($route
->hasScheme('http'));
$route
->setSchemes('hTTp');
$this
->assertEquals(array(
'http',
), $route
->getSchemes(), '->setSchemes() accepts a single scheme string and lowercases it');
$this
->assertTrue($route
->hasScheme('htTp'));
$this
->assertFalse($route
->hasScheme('httpS'));
$route
->setSchemes(array(
'HttpS',
'hTTp',
));
$this
->assertEquals(array(
'https',
'http',
), $route
->getSchemes(), '->setSchemes() accepts an array of schemes and lowercases them');
$this
->assertTrue($route
->hasScheme('htTp'));
$this
->assertTrue($route
->hasScheme('httpS'));
}
/**
* @group legacy
*/
public function testLegacySchemeRequirement() {
$route = new Route('/');
$route
->setRequirement('_scheme', 'http|https');
$this
->assertEquals('http|https', $route
->getRequirement('_scheme'));
$this
->assertEquals(array(
'http',
'https',
), $route
->getSchemes());
$this
->assertTrue($route
->hasScheme('https'));
$this
->assertTrue($route
->hasScheme('http'));
$this
->assertFalse($route
->hasScheme('ftp'));
$route
->setSchemes(array(
'hTTp',
));
$this
->assertEquals('http', $route
->getRequirement('_scheme'));
$route
->setSchemes(array());
$this
->assertNull($route
->getRequirement('_scheme'));
}
public function testMethod() {
$route = new Route('/');
$this
->assertEquals(array(), $route
->getMethods(), 'methods is initialized with array()');
$route
->setMethods('gEt');
$this
->assertEquals(array(
'GET',
), $route
->getMethods(), '->setMethods() accepts a single method string and uppercases it');
$route
->setMethods(array(
'gEt',
'PosT',
));
$this
->assertEquals(array(
'GET',
'POST',
), $route
->getMethods(), '->setMethods() accepts an array of methods and uppercases them');
}
/**
* @group legacy
*/
public function testLegacyMethodRequirement() {
$route = new Route('/');
$route
->setRequirement('_method', 'GET|POST');
$this
->assertEquals('GET|POST', $route
->getRequirement('_method'));
$this
->assertEquals(array(
'GET',
'POST',
), $route
->getMethods());
$route
->setMethods(array(
'gEt',
));
$this
->assertEquals('GET', $route
->getRequirement('_method'));
$route
->setMethods(array());
$this
->assertNull($route
->getRequirement('_method'));
}
public function testCondition() {
$route = new Route('/');
$this
->assertSame('', $route
->getCondition());
$route
->setCondition('context.getMethod() == "GET"');
$this
->assertSame('context.getMethod() == "GET"', $route
->getCondition());
}
public function testCompile() {
$route = new Route('/{foo}');
$this
->assertInstanceOf('Symfony\\Component\\Routing\\CompiledRoute', $compiled = $route
->compile(), '->compile() returns a compiled route');
$this
->assertSame($compiled, $route
->compile(), '->compile() only compiled the route once if unchanged');
$route
->setRequirement('foo', '.*');
$this
->assertNotSame($compiled, $route
->compile(), '->compile() recompiles if the route was modified');
}
/**
* @group legacy
*/
public function testLegacyPattern() {
$route = new Route('/{foo}');
$this
->assertEquals('/{foo}', $route
->getPattern());
$route
->setPattern('/bar');
$this
->assertEquals('/bar', $route
->getPattern());
}
public function testSerialize() {
$route = new Route('/prefix/{foo}', array(
'foo' => 'default',
), array(
'foo' => '\\d+',
));
$serialized = serialize($route);
$unserialized = unserialize($serialized);
$this
->assertEquals($route, $unserialized);
$this
->assertNotSame($route, $unserialized);
}
/**
* Tests that the compiled version is also serialized to prevent the overhead
* of compiling it again after unserialize.
*/
public function testSerializeWhenCompiled() {
$route = new Route('/prefix/{foo}', array(
'foo' => 'default',
), array(
'foo' => '\\d+',
));
$route
->setHost('{locale}.example.net');
$route
->compile();
$serialized = serialize($route);
$unserialized = unserialize($serialized);
$this
->assertEquals($route, $unserialized);
$this
->assertNotSame($route, $unserialized);
}
/**
* Tests that the serialized representation of a route in one symfony version
* also works in later symfony versions, i.e. the unserialized route is in the
* same state as another, semantically equivalent, route.
*/
public function testSerializedRepresentationKeepsWorking() {
$serialized = 'C:31:"Symfony\\Component\\Routing\\Route":934:{a:8:{s:4:"path";s:13:"/prefix/{foo}";s:4:"host";s:20:"{locale}.example.net";s:8:"defaults";a:1:{s:3:"foo";s:7:"default";}s:12:"requirements";a:1:{s:3:"foo";s:3:"\\d+";}s:7:"options";a:1:{s:14:"compiler_class";s:39:"Symfony\\Component\\Routing\\RouteCompiler";}s:7:"schemes";a:0:{}s:7:"methods";a:0:{}s:8:"compiled";C:39:"Symfony\\Component\\Routing\\CompiledRoute":569:{a:8:{s:4:"vars";a:2:{i:0;s:6:"locale";i:1;s:3:"foo";}s:11:"path_prefix";s:7:"/prefix";s:10:"path_regex";s:30:"#^/prefix(?:/(?P<foo>\\d+))?$#s";s:11:"path_tokens";a:2:{i:0;a:4:{i:0;s:8:"variable";i:1;s:1:"/";i:2;s:3:"\\d+";i:3;s:3:"foo";}i:1;a:2:{i:0;s:4:"text";i:1;s:7:"/prefix";}}s:9:"path_vars";a:1:{i:0;s:3:"foo";}s:10:"host_regex";s:39:"#^(?P<locale>[^\\.]++)\\.example\\.net$#si";s:11:"host_tokens";a:2:{i:0;a:2:{i:0;s:4:"text";i:1;s:12:".example.net";}i:1;a:4:{i:0;s:8:"variable";i:1;s:0:"";i:2;s:7:"[^\\.]++";i:3;s:6:"locale";}}s:9:"host_vars";a:1:{i:0;s:6:"locale";}}}}}';
$unserialized = unserialize($serialized);
$route = new Route('/prefix/{foo}', array(
'foo' => 'default',
), array(
'foo' => '\\d+',
));
$route
->setHost('{locale}.example.net');
$route
->compile();
$this
->assertEquals($route, $unserialized);
$this
->assertNotSame($route, $unserialized);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | @group legacy | |
RouteTest:: |
public | function | @group legacy | |
RouteTest:: |
public | function | @group legacy | |
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | ||
RouteTest:: |
public | function | Tests that the serialized representation of a route in one symfony version also works in later symfony versions, i.e. the unserialized route is in the same state as another, semantically equivalent, route. | |
RouteTest:: |
public | function | Tests that the compiled version is also serialized to prevent the overhead of compiling it again after unserialize. | |
RouteTest:: |
public | function | @dataProvider getInvalidRequirements @expectedException \InvalidArgumentException |