123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- <?php
-
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
-
- namespace Symfony\Tests\Component\Routing;
-
- use Symfony\Component\Routing\RouteCollection;
- use Symfony\Component\Routing\Route;
- use Symfony\Component\Config\Resource\FileResource;
-
- class RouteCollectionTest extends \PHPUnit_Framework_TestCase
- {
- public function testRoute()
- {
- $collection = new RouteCollection();
- $route = new Route('/foo');
- $collection->add('foo', $route);
- $this->assertEquals(array('foo' => $route), $collection->all(), '->add() adds a route');
- $this->assertEquals($route, $collection->get('foo'), '->get() returns a route by name');
- $this->assertNull($collection->get('bar'), '->get() returns null if a route does not exist');
- }
-
- /**
- * @expectedException InvalidArgumentException
- */
- public function testAddInvalidRoute()
- {
- $collection = new RouteCollection();
- $route = new Route('/foo');
- $collection->add('f o o', $route);
- }
-
- public function testOverridenRoute()
- {
- $collection = new RouteCollection();
- $collection->add('foo', new Route('/foo'));
- $collection->add('foo', new Route('/foo1'));
-
- $this->assertEquals('/foo1', $collection->get('foo')->getPattern());
- }
-
- public function testDeepOverridenRoute()
- {
- $collection = new RouteCollection();
- $collection->add('foo', new Route('/foo'));
-
- $collection1 = new RouteCollection();
- $collection1->add('foo', new Route('/foo1'));
-
- $collection2 = new RouteCollection();
- $collection2->add('foo', new Route('/foo2'));
-
- $collection1->addCollection($collection2);
- $collection->addCollection($collection1);
-
- $this->assertEquals('/foo2', $collection1->get('foo')->getPattern());
- $this->assertEquals('/foo2', $collection->get('foo')->getPattern());
- }
-
- public function testIteratorWithOverridenRoutes()
- {
- $collection = new RouteCollection();
- $collection->add('foo', new Route('/foo'));
-
- $collection1 = new RouteCollection();
- $collection->addCollection($collection1);
- $collection1->add('foo', new Route('/foo1'));
-
- $this->assertEquals('/foo1', $this->getFirstNamedRoute($collection, 'foo')->getPattern());
- }
-
- protected function getFirstNamedRoute(RouteCollection $routeCollection, $name)
- {
- foreach ($routeCollection as $key => $route) {
- if ($route instanceof RouteCollection) {
- return $this->getFirstNamedRoute($route, $name);
- }
-
- if ($name === $key) {
- return $route;
- }
- }
- }
-
- public function testAddCollection()
- {
- $collection = new RouteCollection();
- $collection->add('foo', $foo = new Route('/foo'));
- $collection1 = new RouteCollection();
- $collection1->add('foo', $foo1 = new Route('/foo1'));
- $collection1->add('bar', $bar1 = new Route('/bar1'));
- $collection->addCollection($collection1);
- $this->assertEquals(array('foo' => $foo1, 'bar' => $bar1), $collection->all(), '->addCollection() adds routes from another collection');
-
- $collection = new RouteCollection();
- $collection->add('foo', $foo = new Route('/foo'));
- $collection1 = new RouteCollection();
- $collection1->add('foo', $foo1 = new Route('/foo1'));
- $collection->addCollection($collection1, '/foo');
- $this->assertEquals('/foo/foo1', $collection->get('foo')->getPattern(), '->addCollection() can add a prefix to all merged routes');
-
- $collection = new RouteCollection();
- $collection->addResource($foo = new FileResource(__DIR__.'/Fixtures/foo.xml'));
- $collection1 = new RouteCollection();
- $collection1->addResource($foo1 = new FileResource(__DIR__.'/Fixtures/foo1.xml'));
- $collection->addCollection($collection1);
- $this->assertEquals(array($foo, $foo1), $collection->getResources(), '->addCollection() merges resources');
- }
-
- public function testAddPrefix()
- {
- $collection = new RouteCollection();
- $collection->add('foo', $foo = new Route('/foo'));
- $collection->add('bar', $bar = new Route('/bar'));
- $collection->addPrefix('/admin');
- $this->assertEquals('/admin/foo', $collection->get('foo')->getPattern(), '->addPrefix() adds a prefix to all routes');
- $this->assertEquals('/admin/bar', $collection->get('bar')->getPattern(), '->addPrefix() adds a prefix to all routes');
- }
-
- public function testResource()
- {
- $collection = new RouteCollection();
- $collection->addResource($foo = new FileResource(__DIR__.'/Fixtures/foo.xml'));
- $this->assertEquals(array($foo), $collection->getResources(), '->addResources() adds a resource');
- }
- }
|