RouteCollectionTest.php 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. *
  5. * (c) Fabien Potencier <fabien.potencier@symfony-project.com>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Symfony\Tests\Component\Routing;
  11. use Symfony\Component\Routing\RouteCollection;
  12. use Symfony\Component\Routing\Route;
  13. use Symfony\Component\Routing\Resource\FileResource;
  14. class RouteCollectionTest extends \PHPUnit_Framework_TestCase
  15. {
  16. public function testRoute()
  17. {
  18. $collection = new RouteCollection();
  19. $route = new Route('/foo');
  20. $collection->addRoute('foo', $route);
  21. $this->assertEquals(array('foo' => $route), $collection->getRoutes(), '->addRoute() adds a route');
  22. $this->assertEquals($route, $collection->getRoute('foo'), '->getRoute() returns a route by name');
  23. $this->assertNull($collection->getRoute('bar'), '->getRoute() returns null if a route does not exist');
  24. }
  25. public function testAddCollection()
  26. {
  27. $collection = new RouteCollection();
  28. $collection->addRoute('foo', $foo = new Route('/foo'));
  29. $collection1 = new RouteCollection();
  30. $collection1->addRoute('foo', $foo1 = new Route('/foo1'));
  31. $collection1->addRoute('bar', $bar1 = new Route('/bar1'));
  32. $collection->addCollection($collection1);
  33. $this->assertEquals(array('foo' => $foo1, 'bar' => $bar1), $collection->getRoutes(), '->addCollection() adds routes from another collection');
  34. $collection = new RouteCollection();
  35. $collection->addRoute('foo', $foo = new Route('/foo'));
  36. $collection1 = new RouteCollection();
  37. $collection1->addRoute('foo', $foo1 = new Route('/foo1'));
  38. $collection->addCollection($collection1, '/foo');
  39. $this->assertEquals('/foo/foo1', $collection->getRoute('foo')->getPattern(), '->addCollection() can add a prefix to all merged routes');
  40. $collection = new RouteCollection();
  41. $collection->addResource($foo = new FileResource(__DIR__.'/Fixtures/foo.xml'));
  42. $collection1 = new RouteCollection();
  43. $collection1->addResource($foo1 = new FileResource(__DIR__.'/Fixtures/foo1.xml'));
  44. $collection->addCollection($collection1);
  45. $this->assertEquals(array($foo, $foo1), $collection->getResources(), '->addCollection() merges resources');
  46. }
  47. public function testAddPrefix()
  48. {
  49. $collection = new RouteCollection();
  50. $collection->addRoute('foo', $foo = new Route('/foo'));
  51. $collection->addRoute('bar', $bar = new Route('/bar'));
  52. $collection->addPrefix('/admin');
  53. $this->assertEquals('/admin/foo', $collection->getRoute('foo')->getPattern(), '->addPrefix() adds a prefix to all routes');
  54. $this->assertEquals('/admin/bar', $collection->getRoute('bar')->getPattern(), '->addPrefix() adds a prefix to all routes');
  55. }
  56. public function testResource()
  57. {
  58. $collection = new RouteCollection();
  59. $collection->addResource($foo = new FileResource(__DIR__.'/Fixtures/foo.xml'));
  60. $this->assertEquals(array($foo), $collection->getResources(), '->addResources() adds a resource');
  61. }
  62. }