class DumperPrefixCollectionTest

Hierarchy

  • class \Symfony\Component\Routing\Tests\Matcher\Dumper\DumperPrefixCollectionTest extends \Symfony\Component\Routing\Tests\Matcher\Dumper\PHPUnit_Framework_TestCase

Expanded class hierarchy of DumperPrefixCollectionTest

File

drupal/core/vendor/symfony/routing/Symfony/Component/Routing/Tests/Matcher/Dumper/DumperPrefixCollectionTest.php, line 19

Namespace

Symfony\Component\Routing\Tests\Matcher\Dumper
View source
class DumperPrefixCollectionTest extends \PHPUnit_Framework_TestCase {
  public function testAddPrefixRoute() {
    $coll = new DumperPrefixCollection();
    $coll
      ->setPrefix('');
    $route = new DumperRoute('bar', new Route('/foo/bar'));
    $coll = $coll
      ->addPrefixRoute($route);
    $route = new DumperRoute('bar2', new Route('/foo/bar'));
    $coll = $coll
      ->addPrefixRoute($route);
    $route = new DumperRoute('qux', new Route('/foo/qux'));
    $coll = $coll
      ->addPrefixRoute($route);
    $route = new DumperRoute('bar3', new Route('/foo/bar'));
    $coll = $coll
      ->addPrefixRoute($route);
    $route = new DumperRoute('bar4', new Route(''));
    $result = $coll
      ->addPrefixRoute($route);
    $expect = <<<'EOF'
            |-coll /
            | |-coll /f
            | | |-coll /fo
            | | | |-coll /foo
            | | | | |-coll /foo/
            | | | | | |-coll /foo/b
            | | | | | | |-coll /foo/ba
            | | | | | | | |-coll /foo/bar
            | | | | | | | | |-route bar /foo/bar
            | | | | | | | | |-route bar2 /foo/bar
            | | | | | |-coll /foo/q
            | | | | | | |-coll /foo/qu
            | | | | | | | |-coll /foo/qux
            | | | | | | | | |-route qux /foo/qux
            | | | | | |-coll /foo/b
            | | | | | | |-coll /foo/ba
            | | | | | | | |-coll /foo/bar
            | | | | | | | | |-route bar3 /foo/bar
            | |-route bar4 /

EOF;
    $this
      ->assertSame($expect, $this
      ->collectionToString($result
      ->getRoot(), '            '));
  }
  public function testMergeSlashNodes() {
    $coll = new DumperPrefixCollection();
    $coll
      ->setPrefix('');
    $route = new DumperRoute('bar', new Route('/foo/bar'));
    $coll = $coll
      ->addPrefixRoute($route);
    $route = new DumperRoute('bar2', new Route('/foo/bar'));
    $coll = $coll
      ->addPrefixRoute($route);
    $route = new DumperRoute('qux', new Route('/foo/qux'));
    $coll = $coll
      ->addPrefixRoute($route);
    $route = new DumperRoute('bar3', new Route('/foo/bar'));
    $result = $coll
      ->addPrefixRoute($route);
    $result
      ->getRoot()
      ->mergeSlashNodes();
    $expect = <<<'EOF'
            |-coll /f
            | |-coll /fo
            | | |-coll /foo
            | | | |-coll /foo/b
            | | | | |-coll /foo/ba
            | | | | | |-coll /foo/bar
            | | | | | | |-route bar /foo/bar
            | | | | | | |-route bar2 /foo/bar
            | | | |-coll /foo/q
            | | | | |-coll /foo/qu
            | | | | | |-coll /foo/qux
            | | | | | | |-route qux /foo/qux
            | | | |-coll /foo/b
            | | | | |-coll /foo/ba
            | | | | | |-coll /foo/bar
            | | | | | | |-route bar3 /foo/bar

EOF;
    $this
      ->assertSame($expect, $this
      ->collectionToString($result
      ->getRoot(), '            '));
  }
  private function collectionToString(DumperCollection $collection, $prefix) {
    $string = '';
    foreach ($collection as $route) {
      if ($route instanceof DumperCollection) {
        $string .= sprintf("%s|-coll %s\n", $prefix, $route
          ->getPrefix());
        $string .= $this
          ->collectionToString($route, $prefix . '| ');
      }
      else {
        $string .= sprintf("%s|-route %s %s\n", $prefix, $route
          ->getName(), $route
          ->getRoute()
          ->getPath());
      }
    }
    return $string;
  }

}

Members