5 * Contains \Drupal\Tests\Component\HttpFoundation\SecuredRedirectResponseTest.
8 namespace Drupal\Tests\Component\HttpFoundation;
10 use Drupal\Component\HttpFoundation\SecuredRedirectResponse;
11 use Drupal\Tests\UnitTestCase;
12 use Symfony\Component\HttpFoundation\Cookie;
13 use Symfony\Component\HttpFoundation\RedirectResponse;
16 * Test secure redirect base class.
19 * @coversDefaultClass \Drupal\Component\HttpFoundation\SecuredRedirectResponse
21 class SecuredRedirectResponseTest extends UnitTestCase {
24 * Test copying of redirect response.
26 * @covers ::createFromRedirectResponse
27 * @covers ::fromResponse
29 public function testRedirectCopy() {
30 $redirect = new RedirectResponse('/magic_redirect_url', 301, ['x-cache-foobar' => 123]);
31 $redirect->setProtocolVersion('2.0');
32 $redirect->setCharset('ibm-943_P14A-2000');
33 $redirect->headers->setCookie(new Cookie('name', 'value'));
35 // Make a cloned redirect.
36 $secureRedirect = SecuredRedirectStub::createFromRedirectResponse($redirect);
37 $this->assertEquals('/magic_redirect_url', $secureRedirect->getTargetUrl());
38 $this->assertEquals(301, $secureRedirect->getStatusCode());
39 // We pull the headers from the original redirect because there are default headers applied.
40 $headers1 = $redirect->headers->allPreserveCase();
41 $headers2 = $secureRedirect->headers->allPreserveCase();
42 // We unset cache headers so we don't test arcane Symfony weirdness.
43 // https://github.com/symfony/symfony/issues/16171
44 unset($headers1['Cache-Control'], $headers2['Cache-Control']);
45 $this->assertEquals($headers1, $headers2);
46 $this->assertEquals('2.0', $secureRedirect->getProtocolVersion());
47 $this->assertEquals('ibm-943_P14A-2000', $secureRedirect->getCharset());
48 $this->assertEquals($redirect->headers->getCookies(), $secureRedirect->headers->getCookies());
53 class SecuredRedirectStub extends SecuredRedirectResponse {
58 protected function isSafe($url) {
59 // Empty implementation for testing.