-
-
Notifications
You must be signed in to change notification settings - Fork 1.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Replace header when sending first of each header
When we call `header()` to send the headers in the Response, set the `replace` parameter to true for the first of that header name and then set it to false. Don't do this if the header is Set-Cookie so we don't break sessions. Fixes #2282 Fixes #2246
- Loading branch information
Showing
4 changed files
with
216 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,114 @@ | ||
<?php | ||
/** | ||
* This is a direct copy of zend-diactoros/test/TestAsset/Functions.php and is used to override | ||
* header() and headers_sent() so we can test that they do the right thing. | ||
* | ||
* We put these into the Slim namespace, so that Slim\App will use these versions of header() and | ||
* headers_sent() when we test its output. | ||
*/ | ||
namespace Slim; | ||
|
||
/** | ||
* Zend Framework (http://framework.zend.com/) | ||
* | ||
* This file exists to allow overriding the various output-related functions | ||
* in order to test what happens during the `Server::listen()` cycle. | ||
* | ||
* These functions include: | ||
* | ||
* - headers_sent(): we want to always return false so that headers will be | ||
* emitted, and we can test to see their values. | ||
* - header(): we want to aggregate calls to this function. | ||
* | ||
* The HeaderStack class then aggregates that information for us, and the test | ||
* harness resets the values pre and post test. | ||
* | ||
* @see http://github.com/zendframework/zend-diactoros for the canonical source repository | ||
* @copyright Copyright (c) 2015-2016 Zend Technologies USA Inc. (http://www.zend.com) | ||
* @license https://github.com/zendframework/zend-diactoros/blob/master/LICENSE.md New BSD License | ||
*/ | ||
|
||
/** | ||
* Store output artifacts | ||
*/ | ||
class HeaderStackTestAsset | ||
{ | ||
/** | ||
* @var string[][] | ||
*/ | ||
private static $data = []; | ||
|
||
/** | ||
* Reset state | ||
*/ | ||
public static function reset() | ||
{ | ||
self::$data = []; | ||
} | ||
|
||
/** | ||
* Push a header on the stack | ||
* | ||
* @param string[] $header | ||
*/ | ||
public static function push(array $header) | ||
{ | ||
self::$data[] = $header; | ||
} | ||
|
||
/** | ||
* Return the current header stack | ||
* | ||
* @return string[][] | ||
*/ | ||
public static function stack() | ||
{ | ||
return self::$data; | ||
} | ||
|
||
/** | ||
* Verify if there's a header line on the stack | ||
* | ||
* @param string $header | ||
* | ||
* @return bool | ||
*/ | ||
public static function has($header) | ||
{ | ||
foreach (self::$data as $item) { | ||
if ($item['header'] === $header) { | ||
return true; | ||
} | ||
} | ||
|
||
return false; | ||
} | ||
} | ||
|
||
/** | ||
* Have headers been sent? | ||
* | ||
* @return false | ||
*/ | ||
function headers_sent() | ||
{ | ||
return false; | ||
} | ||
|
||
/** | ||
* Emit a header, without creating actual output artifacts | ||
* | ||
* @param string $string | ||
* @param bool $replace | ||
* @param int|null $statusCode | ||
*/ | ||
function header($string, $replace = true, $statusCode = null) | ||
{ | ||
HeaderStackTestAsset::push( | ||
[ | ||
'header' => $string, | ||
'replace' => $replace, | ||
'status_code' => $statusCode, | ||
] | ||
); | ||
} |