class RouteCompilerTest in Drupal 8
Same name and namespace in other branches
- 9 core/tests/Drupal/Tests/Core/Routing/RouteCompilerTest.php \Drupal\Tests\Core\Routing\RouteCompilerTest
- 10 core/tests/Drupal/Tests/Core/Routing/RouteCompilerTest.php \Drupal\Tests\Core\Routing\RouteCompilerTest
@coversDefaultClass \Drupal\Core\Routing\RouteCompiler @group Routing
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses PhpunitCompatibilityTrait- class \Drupal\Tests\Core\Routing\RouteCompilerTest
 
Expanded class hierarchy of RouteCompilerTest
File
- core/tests/ Drupal/ Tests/ Core/ Routing/ RouteCompilerTest.php, line 14 
Namespace
Drupal\Tests\Core\RoutingView source
class RouteCompilerTest extends UnitTestCase {
  /**
   * Tests RouteCompiler::getFit().
   *
   * @param string $path
   *   A path whose fit will be calculated in the test.
   * @param int $expected
   *   The expected fit returned by RouteCompiler::getFit()
   *
   * @dataProvider providerTestGetFit
   */
  public function testGetFit($path, $expected) {
    $route_compiler = new RouteCompiler();
    $result = $route_compiler
      ->getFit($path);
    $this
      ->assertSame($expected, $result);
  }
  /**
   * Provides data for RouteCompilerTest::testGetFit()
   *
   * @return array
   *   An array of arrays, where each inner array has the path whose fit is to
   *   be calculated as the first value and the expected fit as the second
   *   value.
   */
  public function providerTestGetFit() {
    return [
      [
        'test',
        1,
      ],
      [
        '/testwithleadingslash',
        1,
      ],
      [
        'testwithtrailingslash/',
        1,
      ],
      [
        '/testwithslashes/',
        1,
      ],
      [
        'test/with/multiple/parts',
        15,
      ],
      [
        'test/with/{some}/slugs',
        13,
      ],
      [
        'test/very/long/path/that/drupal/7/could/not/have/handled',
        2047,
      ],
    ];
  }
  /**
   * Confirms that a route compiles properly with the necessary data.
   */
  public function testCompilation() {
    $route = new Route('/test/{something}/more');
    $route
      ->setOption('compiler_class', RouteCompiler::class);
    $compiled = $route
      ->compile();
    $this
      ->assertEquals($compiled
      ->getFit(), 5, 'The fit was incorrect.');
    $this
      ->assertEquals($compiled
      ->getPatternOutline(), '/test/%/more', 'The pattern outline was not correct.');
  }
  /**
   * Confirms that a compiled route with default values has the correct outline.
   */
  public function testCompilationDefaultValue() {
    // Because "here" has a default value, it should not factor into the outline
    // or the fitness.
    $route = new Route('/test/{something}/more/{here}', [
      'here' => 'there',
    ]);
    $route
      ->setOption('compiler_class', RouteCompiler::class);
    $compiled = $route
      ->compile();
    $this
      ->assertEquals($compiled
      ->getFit(), 5, 'The fit was not correct.');
    $this
      ->assertEquals($compiled
      ->getPatternOutline(), '/test/%/more', 'The pattern outline was not correct.');
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| PhpunitCompatibilityTrait:: | public | function | Returns a mock object for the specified class using the available method. | |
| PhpunitCompatibilityTrait:: | public | function | Compatibility layer for PHPUnit 6 to support PHPUnit 4 code. | |
| RouteCompilerTest:: | public | function | Provides data for RouteCompilerTest::testGetFit() | |
| RouteCompilerTest:: | public | function | Confirms that a route compiles properly with the necessary data. | |
| RouteCompilerTest:: | public | function | Confirms that a compiled route with default values has the correct outline. | |
| RouteCompilerTest:: | public | function | Tests RouteCompiler::getFit(). | |
| UnitTestCase:: | protected | property | The random generator. | |
| UnitTestCase:: | protected | property | The app root. | 1 | 
| UnitTestCase:: | protected | function | Asserts if two arrays are equal by sorting them first. | |
| UnitTestCase:: | protected | function | Mocks a block with a block plugin. | 1 | 
| UnitTestCase:: | protected | function | Returns a stub class resolver. | |
| UnitTestCase:: | public | function | Returns a stub config factory that behaves according to the passed array. | |
| UnitTestCase:: | public | function | Returns a stub config storage that returns the supplied configuration. | |
| UnitTestCase:: | protected | function | Sets up a container with a cache tags invalidator. | |
| UnitTestCase:: | protected | function | Gets the random generator for the utility methods. | |
| UnitTestCase:: | public | function | Returns a stub translation manager that just returns the passed string. | |
| UnitTestCase:: | public | function | Generates a unique random string containing letters and numbers. | |
| UnitTestCase:: | protected | function | 340 | 
