TestControllers.php

Same filename in this branch
  1. 9 core/modules/system/tests/modules/paramconverter_test/src/TestControllers.php
  2. 9 core/modules/system/tests/modules/menu_test/src/TestControllers.php
Same filename in other branches
  1. 8.9.x core/modules/system/tests/modules/paramconverter_test/src/TestControllers.php
  2. 8.9.x core/modules/system/tests/modules/menu_test/src/TestControllers.php
  3. 8.9.x core/modules/system/tests/modules/router_test_directory/src/TestControllers.php
  4. 10 core/modules/system/tests/modules/paramconverter_test/src/TestControllers.php
  5. 10 core/modules/system/tests/modules/menu_test/src/TestControllers.php
  6. 10 core/modules/system/tests/modules/router_test_directory/src/TestControllers.php
  7. 11.x core/modules/system/tests/modules/paramconverter_test/src/TestControllers.php
  8. 11.x core/modules/system/tests/modules/menu_test/src/TestControllers.php
  9. 11.x core/modules/system/tests/modules/router_test_directory/src/TestControllers.php

Namespace

Drupal\router_test

File

core/modules/system/tests/modules/router_test_directory/src/TestControllers.php

View source
<?php

namespace Drupal\router_test;

use Drupal\Core\Cache\CacheableResponse;
use Drupal\Core\ParamConverter\ParamNotConvertedException;
use Drupal\user\UserInterface;
use Drupal\Core\Routing\RouteObjectInterface;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Laminas\Diactoros\Response\HtmlResponse;

/**
 * Controller routines for testing the routing system.
 */
class TestControllers {
    const LONG_TEXT = 'This is text long enough to trigger Apache mod_deflate to add a `vary: accept-encoding` header to the response.';
    public function test() {
        return new Response('test');
    }
    public function test1() {
        return new Response(self::LONG_TEXT);
    }
    public function test2() {
        return [
            '#markup' => "test2",
        ];
    }
    public function test3($value) {
        return [
            '#markup' => $value,
        ];
    }
    public function test4($value) {
        return [
            '#markup' => $value,
        ];
    }
    public function test5() {
        return [
            '#markup' => "test5",
        ];
    }
    public function test6() {
        return new Response('test6');
    }
    public function test7() {
        return new Response('test7text');
    }
    public function test8() {
        return new Response('test8');
    }
    public function test9($uid) {
        $text = 'Route not matched.';
        try {
            $match = \Drupal::service('router.no_access_checks')->match('/user/' . $uid);
            if (isset($match['user']) && $match['user'] instanceof UserInterface) {
                $text = sprintf('User route "%s" was matched.', $match[RouteObjectInterface::ROUTE_NAME]);
            }
        } catch (ParamNotConvertedException $e) {
        }
        return new Response($text);
    }
    
    /**
     * Tests controller for ExceptionHandlingTest::testBacktraceEscaping().
     *
     * Passes unsafe HTML as an argument to a method which throws an exception.
     * This can be used to test if the generated backtrace is properly escaped.
     */
    public function test10() {
        $this->removeExceptionLogger();
        $this->throwException('<script>alert(\'xss\')</script>');
    }
    public function test18() {
        return [
            '#cache' => [
                'contexts' => [
                    'url',
                ],
                'tags' => [
                    'foo',
                ],
                'max-age' => 60,
            ],
            'content' => [
                '#markup' => 'test18',
            ],
        ];
    }
    public function test21() {
        return new CacheableResponse('test21');
    }
    public function test23() {
        return new HtmlResponse('test23');
    }
    public function test24() {
        $this->removeExceptionLogger();
        throw new \Exception('Escaped content: <p> <br> <h3>');
    }
    public function test25() {
        return [
            '#cache' => [
                'url',
            ],
            '#markup' => \Drupal::requestStack()->getCurrentRequest()
                ->getUri(),
        ];
    }
    public function testRouteName(Request $request) {
        return [
            '#markup' => $request->attributes
                ->get(RouteObjectInterface::ROUTE_NAME),
        ];
    }
    
    /**
     * Throws an exception.
     *
     * @param string $message
     *   The message to use in the exception.
     *
     * @throws \Exception
     *   Always thrown.
     */
    protected function throwException($message) {
        throw new \Exception($message);
    }
    protected function removeExceptionLogger() {
        // Remove the exception logger from the event dispatcher. We are going to
        // throw an exception to check if it is properly escaped when rendered as a
        // backtrace. The exception logger does a call to error_log() which is not
        // handled by the Simpletest error handler and would cause a test failure.
        $event_dispatcher = \Drupal::service('event_dispatcher');
        $exception_logger = \Drupal::service('exception.logger');
        $event_dispatcher->removeSubscriber($exception_logger);
    }

}

Classes

Title Deprecated Summary
TestControllers Controller routines for testing the routing system.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.