You are here

class RouteTest in Zircon Profile 8

Same name in this branch
  1. 8 vendor/symfony/routing/Tests/RouteTest.php \Symfony\Component\Routing\Tests\RouteTest
  2. 8 vendor/symfony/routing/Tests/Annotation/RouteTest.php \Symfony\Component\Routing\Tests\Annotation\RouteTest
Same name and namespace in other branches
  1. 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\Tests
View 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

Namesort descending Modifiers Type Description Overrides
RouteTest::getInvalidRequirements public function
RouteTest::testCompile public function
RouteTest::testCondition public function
RouteTest::testConstructor public function
RouteTest::testDefaults public function
RouteTest::testHost public function
RouteTest::testLegacyMethodRequirement public function @group legacy
RouteTest::testLegacyPattern public function @group legacy
RouteTest::testLegacySchemeRequirement public function @group legacy
RouteTest::testMethod public function
RouteTest::testOption public function
RouteTest::testOptions public function
RouteTest::testPath public function
RouteTest::testRequirement public function
RouteTest::testRequirements public function
RouteTest::testScheme public function
RouteTest::testSerialize public function
RouteTest::testSerializedRepresentationKeepsWorking 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::testSerializeWhenCompiled public function Tests that the compiled version is also serialized to prevent the overhead of compiling it again after unserialize.
RouteTest::testSetInvalidRequirement public function @dataProvider getInvalidRequirements @expectedException \InvalidArgumentException