private function MatchPathTest::drupalMatchPathTests

Helper function for testDrupalMatchPath(): set up an array of test cases.

Return value

An array of test cases to cycle through.

1 call to MatchPathTest::drupalMatchPathTests()
MatchPathTest::testDrupalMatchPath in drupal/core/modules/system/lib/Drupal/system/Tests/Path/MatchPathTest.php
Run through our test cases, making sure each one works as expected.

File

drupal/core/modules/system/lib/Drupal/system/Tests/Path/MatchPathTest.php, line 59
Definition of Drupal\system\Tests\Path\MatchPathTest.

Class

MatchPathTest
Unit tests for the drupal_match_path() function in path.inc.

Namespace

Drupal\system\Tests\Path

Code

private function drupalMatchPathTests() {
  return array(
    // Single absolute paths.
    'example/1' => array(
      'example/1' => TRUE,
      'example/2' => FALSE,
      'test' => FALSE,
    ),
    // Single paths with wildcards.
    'example/*' => array(
      'example/1' => TRUE,
      'example/2' => TRUE,
      'example/3/edit' => TRUE,
      'example/' => TRUE,
      'example' => FALSE,
      'test' => FALSE,
    ),
    // Single paths with multiple wildcards.
    'node/*/revisions/*' => array(
      'node/1/revisions/3' => TRUE,
      'node/345/revisions/test' => TRUE,
      'node/23/edit' => FALSE,
      'test' => FALSE,
    ),
    // Single paths with '<front>'.
    '<front>' => array(
      $this->front => TRUE,
      "{$this->front}/" => FALSE,
      "{$this->front}/edit" => FALSE,
      'node' => FALSE,
      '' => FALSE,
    ),
    // Paths with both '<front>' and wildcards (should not work).
    '<front>/*' => array(
      $this->front => FALSE,
      "{$this->front}/" => FALSE,
      "{$this->front}/edit" => FALSE,
      'node/12' => FALSE,
      '' => FALSE,
    ),
    // Multiple paths with the \n delimiter.
    "node/*\nnode/*/edit" => array(
      'node/1' => TRUE,
      'node/view' => TRUE,
      'node/32/edit' => TRUE,
      'node/delete/edit' => TRUE,
      'node/50/delete' => TRUE,
      'test/example' => FALSE,
    ),
    // Multiple paths with the \r delimiter.
    "user/*\rexample/*" => array(
      'user/1' => TRUE,
      'example/1' => TRUE,
      'user/1/example/1' => TRUE,
      'user/example' => TRUE,
      'test/example' => FALSE,
      'user' => FALSE,
      'example' => FALSE,
    ),
    // Multiple paths with the \r\n delimiter.
    "test\r\n<front>" => array(
      'test' => TRUE,
      $this->front => TRUE,
      'example' => FALSE,
    ),
    // Test existing regular expressions (should be escaped).
    '[^/]+?/[0-9]' => array(
      'test/1' => FALSE,
      '[^/]+?/[0-9]' => TRUE,
    ),
  );
}