1 path.test private BackdropMatchPathTestCase::backdropMatchPathTests()

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

Return value

An array of test cases to cycle through.:

File

core/modules/simpletest/tests/path.test, line 46
Tests for path.inc.

Class

BackdropMatchPathTestCase
Unit tests for the backdrop_match_path() function in path.inc.

Code

private function backdropMatchPathTests() {
  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,
    ),
  );
}