RouterTest.php 7.47 KB
Newer Older
1 2
<?php

Crell's avatar
Crell committed
3 4 5 6 7
/**
 * @file
 * Definition of Drupal\system\Tests\Routing\RouterTest.
 */

8 9 10
namespace Drupal\system\Tests\Routing;

use Drupal\simpletest\WebTestBase;
11
use Symfony\Component\Routing\Exception\RouteNotFoundException;
12 13 14

/**
 * Functional class for the full integrated routing system.
15 16
 *
 * @group Routing
17 18 19 20 21 22 23 24 25 26
 */
class RouterTest extends WebTestBase {

  /**
   * Modules to enable.
   *
   * @var array
   */
  public static $modules = array('block', 'router_test');

27 28 29
  /**
   * Confirms that the router can get to a controller.
   */
30 31 32 33 34
  public function testCanRoute() {
    $this->drupalGet('router_test/test1');
    $this->assertRaw('test1', 'The correct string was returned because the route was successful.');
  }

35 36 37 38 39 40
  /**
   * Confirms that our default controller logic works properly.
   */
  public function testDefaultController() {
    $this->drupalGet('router_test/test2');
    $this->assertRaw('test2', 'The correct string was returned because the route was successful.');
41 42 43

    // Confirm that the page wrapping is being added, so we're not getting a
    // raw body returned.
44
    $this->assertRaw('</html>', 'Page markup was found.');
45 46 47 48

    // In some instances, the subrequest handling may get confused and render
    // a page inception style.  This test verifies that is not happening.
    $this->assertNoPattern('#</body>.*</body>#s', 'There was no double-page effect from a misrendered subrequest.');
49 50
  }

51 52 53
  /**
   * Confirms that placeholders in paths work correctly.
   */
54
  public function testControllerPlaceholders() {
55
    // Test with 0 and a random value.
56
    $values = array("0", $this->randomMachineName());
57 58 59 60 61
    foreach ($values as $value) {
      $this->drupalGet('router_test/test3/' . $value);
      $this->assertResponse(200);
      $this->assertRaw($value, 'The correct string was returned because the route was successful.');
    }
62 63 64

    // Confirm that the page wrapping is being added, so we're not getting a
    // raw body returned.
65
    $this->assertRaw('</html>', 'Page markup was found.');
66 67 68 69

    // In some instances, the subrequest handling may get confused and render
    // a page inception style.  This test verifies that is not happening.
    $this->assertNoPattern('#</body>.*</body>#s', 'There was no double-page effect from a misrendered subrequest.');
70 71
  }

72 73 74 75 76
  /**
   * Confirms that default placeholders in paths work correctly.
   */
  public function testControllerPlaceholdersDefaultValues() {
    $this->drupalGet('router_test/test4');
77
    $this->assertResponse(200);
78
    $this->assertRaw('narf', 'The correct string was returned because the route was successful.');
79 80

    // Confirm that the page wrapping is being added, so we're not getting a
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97
    // raw body returned.
    $this->assertRaw('</html>', 'Page markup was found.');

    // In some instances, the subrequest handling may get confused and render
    // a page inception style.  This test verifies that is not happening.
    $this->assertNoPattern('#</body>.*</body>#s', 'There was no double-page effect from a misrendered subrequest.');
  }

  /**
   * Confirms that default placeholders in paths work correctly.
   */
  public function testControllerPlaceholdersDefaultValuesProvided() {
    $this->drupalGet('router_test/test4/barf');
    $this->assertResponse(200);
    $this->assertRaw('barf', 'The correct string was returned because the route was successful.');

    // Confirm that the page wrapping is being added, so we're not getting a
98
    // raw body returned.
99
    $this->assertRaw('</html>', 'Page markup was found.');
100 101 102 103

    // In some instances, the subrequest handling may get confused and render
    // a page inception style.  This test verifies that is not happening.
    $this->assertNoPattern('#</body>.*</body>#s', 'There was no double-page effect from a misrendered subrequest.');
104 105
  }

106 107 108 109 110 111 112 113 114 115 116
  /**
   * Checks that dynamically defined and altered routes work correctly.
   *
   * @see \Drupal\router_test\RouteSubscriber
   */
  public function testDynamicRoutes() {
    // Test the altered route.
    $this->drupalGet('router_test/test6');
    $this->assertResponse(200);
    $this->assertRaw('test5', 'The correct string was returned because the route was successful.');
  }
117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134

  /**
   * Checks that a request with text/html response gets rendered as a page.
   */
  public function testControllerResolutionPage() {
    $this->drupalGet('/router_test/test10');

    $this->assertRaw('abcde', 'Correct body was found.');

    // Confirm that the page wrapping is being added, so we're not getting a
    // raw body returned.
    $this->assertRaw('</html>', 'Page markup was found.');

    // In some instances, the subrequest handling may get confused and render
    // a page inception style. This test verifies that is not happening.
    $this->assertNoPattern('#</body>.*</body>#s', 'There was no double-page effect from a misrendered subrequest.');
  }

135 136 137 138 139 140 141 142 143 144
  /**
   * Checks the generate method on the url generator using the front router.
   */
  public function testUrlGeneratorFront() {
    global $base_path;

    $this->assertEqual($this->container->get('url_generator')->generate('<front>'), $base_path);
    $this->assertEqual($this->container->get('url_generator')->generateFromPath('<front>'), $base_path);
  }

145 146 147 148 149 150
  /**
   * Tests that a page trying to match a path will succeed.
   */
  public function testRouterMatching() {
    $this->drupalGet('router_test/test14/1');
    $this->assertResponse(200);
151
    $this->assertText('User route "entity.user.canonical" was matched.');
152 153 154 155 156 157 158

    // Try to match a route for a non-existent user.
    $this->drupalGet('router_test/test14/2');
    $this->assertResponse(200);
    $this->assertText('Route not matched.');
  }

159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176
  /**
   * Tests the user account on the DIC.
   */
  public function testUserAccount() {
    $account = $this->drupalCreateUser();
    $this->drupalLogin($account);

    $second_account = $this->drupalCreateUser();

    $this->drupalGet('router_test/test12/' . $second_account->id());
    $this->assertText($account->getUsername() . ':' . $second_account->getUsername());
    $this->assertEqual($account->id(), $this->loggedInUser->id(), 'Ensure that the user was not changed.');

    $this->drupalGet('router_test/test13/' . $second_account->id());
    $this->assertText($account->getUsername() . ':' . $second_account->getUsername());
    $this->assertEqual($account->id(), $this->loggedInUser->id(), 'Ensure that the user was not changed.');
  }

177 178 179 180 181 182
  /**
   * Checks that an ajax request gets rendered as an Ajax response, by mime.
   */
  public function testControllerResolutionAjax() {
    // This will fail with a JSON parse error if the request is not routed to
    // The correct controller.
183
    $this->drupalGetAJAX('/router_test/test10');
184 185 186 187 188

    $this->assertEqual($this->drupalGetHeader('Content-Type'), 'application/json', 'Correct mime content type was returned');

    $this->assertRaw('abcde', 'Correct body was found.');
  }
189 190 191 192

  /**
   * Tests that routes no longer exist for a module that has been uninstalled.
   */
193
  public function testRouterUninstallInstall() {
194
    \Drupal::moduleHandler()->uninstall(array('router_test'));
195 196 197 198 199 200 201 202 203 204 205
    try {
      \Drupal::service('router.route_provider')->getRouteByName('router_test.1');
      $this->fail('Route was delete on uninstall.');
    }
    catch (RouteNotFoundException $e) {
      $this->pass('Route was delete on uninstall.');
    }
    // Install the module again.
    \Drupal::moduleHandler()->install(array('router_test'));
    $route = \Drupal::service('router.route_provider')->getRouteByName('router_test.1');
    $this->assertNotNull($route, 'Route exists after module installation');
206
  }
207
}