SecuredRedirectResponseTest.php

Same filename and directory in other branches
  1. 11.x core/tests/Drupal/Tests/Component/HttpFoundation/SecuredRedirectResponseTest.php
  2. 10 core/tests/Drupal/Tests/Component/HttpFoundation/SecuredRedirectResponseTest.php
  3. 8.9.x core/tests/Drupal/Tests/Component/HttpFoundation/SecuredRedirectResponseTest.php
  4. main core/tests/Drupal/Tests/Component/HttpFoundation/SecuredRedirectResponseTest.php

Contains \Drupal\Tests\Component\HttpFoundation\SecuredRedirectResponseTest.

Namespace

Drupal\Tests\Component\HttpFoundation

File

core/tests/Drupal/Tests/Component/HttpFoundation/SecuredRedirectResponseTest.php

View source
<?php


/**
 * @file
 * Contains \Drupal\Tests\Component\HttpFoundation\SecuredRedirectResponseTest.
 */

namespace Drupal\Tests\Component\HttpFoundation;

use Drupal\Component\HttpFoundation\SecuredRedirectResponse;
use PHPUnit\Framework\TestCase;
use Symfony\Component\HttpFoundation\Cookie;
use Symfony\Component\HttpFoundation\RedirectResponse;

/**
 * Test secure redirect base class.
 *
 * @group Routing
 * @coversDefaultClass \Drupal\Component\HttpFoundation\SecuredRedirectResponse
 */
class SecuredRedirectResponseTest extends TestCase {
  
  /**
   * Tests copying of redirect response.
   *
   * @covers ::createFromRedirectResponse
   * @covers ::fromResponse
   */
  public function testRedirectCopy() {
    $redirect = new RedirectResponse('/magic_redirect_url', 301, [
      'x-cache-foobar' => 123,
    ]);
    $redirect->setProtocolVersion('2.0');
    $redirect->setCharset('ibm-943_P14A-2000');
    $redirect->headers
      ->setCookie(new Cookie('name', 'value', 0, '/', NULL, FALSE, TRUE, FALSE, NULL));
    // Make a cloned redirect.
    $secureRedirect = SecuredRedirectStub::createFromRedirectResponse($redirect);
    $this->assertEquals('/magic_redirect_url', $secureRedirect->getTargetUrl());
    $this->assertEquals(301, $secureRedirect->getStatusCode());
    // We pull the headers from the original redirect because there are default headers applied.
    $headers1 = $redirect->headers
      ->allPreserveCase();
    $headers2 = $secureRedirect->headers
      ->allPreserveCase();
    // We unset cache headers so we don't test arcane Symfony weirdness.
    // https://github.com/symfony/symfony/issues/16171
    unset($headers1['Cache-Control'], $headers2['Cache-Control']);
    $this->assertEquals($headers1, $headers2);
    $this->assertEquals('2.0', $secureRedirect->getProtocolVersion());
    $this->assertEquals('ibm-943_P14A-2000', $secureRedirect->getCharset());
    $this->assertEquals($redirect->headers
      ->getCookies(), $secureRedirect->headers
      ->getCookies());
  }

}
class SecuredRedirectStub extends SecuredRedirectResponse {
  
  /**
   * {@inheritdoc}
   */
  protected function isSafe($url) {
    // Empty implementation for testing.
    return TRUE;
  }

}

Classes

Title Deprecated Summary
SecuredRedirectResponseTest Test secure redirect base class.
SecuredRedirectStub

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