mirror of
https://github.com/php/php-src.git
synced 2026-04-19 14:01:01 +02:00
This patch adds missing newlines, trims multiple redundant final newlines into a single one, and trims redundant leading newlines in all *.phpt sections. According to POSIX, a line is a sequence of zero or more non-' <newline>' characters plus a terminating '<newline>' character. [1] Files should normally have at least one final newline character. C89 [2] and later standards [3] mention a final newline: "A source file that is not empty shall end in a new-line character, which shall not be immediately preceded by a backslash character." Although it is not mandatory for all files to have a final newline fixed, a more consistent and homogeneous approach brings less of commit differences issues and a better development experience in certain text editors and IDEs. [1] http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap03.html#tag_03_206 [2] https://port70.net/~nsz/c/c89/c89-draft.html#2.1.1.2 [3] https://port70.net/~nsz/c/c99/n1256.html#5.1.1.2
93 lines
2.2 KiB
PHP
93 lines
2.2 KiB
PHP
--TEST--
|
|
Bug #47021 (SoapClient stumbles over WSDL delivered with "Transfer-Encoding: chunked")
|
|
--INI--
|
|
allow_url_fopen=1
|
|
--SKIPIF--
|
|
<?php require 'server.inc'; http_server_skipif('tcp://127.0.0.1:12342'); ?>
|
|
--FILE--
|
|
<?php
|
|
require 'server.inc';
|
|
|
|
function stream_notification_callback($notification_code, $severity, $message, $message_code, $bytes_transferred, $bytes_max) {
|
|
|
|
switch($notification_code) {
|
|
case STREAM_NOTIFY_MIME_TYPE_IS:
|
|
echo "Type='$message'\n";
|
|
break;
|
|
case STREAM_NOTIFY_FILE_SIZE_IS:
|
|
echo "Size=$bytes_max\n";
|
|
break;
|
|
}
|
|
}
|
|
|
|
function do_test($num_spaces, $leave_trailing_space=false) {
|
|
// SOAPClient exhibits the bug because it forces HTTP/1.1,
|
|
// whereas file_get_contents() uses HTTP/1.0 by default.
|
|
$options = [
|
|
'http' => [
|
|
'protocol_version' => '1.1',
|
|
'header' => 'Connection: Close'
|
|
],
|
|
];
|
|
|
|
$ctx = stream_context_create($options);
|
|
stream_context_set_params($ctx, array("notification" => "stream_notification_callback"));
|
|
|
|
$spaces = str_repeat(' ', $num_spaces);
|
|
$trailing = ($leave_trailing_space ? ' ' : '');
|
|
$responses = [
|
|
"data://text/plain,HTTP/1.1 200 OK\r\n"
|
|
. "Content-Type:{$spaces}text/plain{$trailing}\r\n"
|
|
. "Transfer-Encoding:{$spaces}Chunked{$trailing}\r\n\r\n"
|
|
. "5\nHello\n0\n",
|
|
"data://text/plain,HTTP/1.1 200 OK\r\n"
|
|
. "Content-Type\r\n" // Deliberately invalid header
|
|
. "Content-Length:{$spaces}5{$trailing}\r\n\r\n"
|
|
. "World"
|
|
];
|
|
$pid = http_server('tcp://127.0.0.1:12342', $responses);
|
|
|
|
echo file_get_contents('http://127.0.0.1:12342/', false, $ctx);
|
|
echo "\n";
|
|
echo file_get_contents('http://127.0.0.1:12342/', false, $ctx);
|
|
echo "\n";
|
|
|
|
http_server_kill($pid);
|
|
}
|
|
|
|
// Chunked decoding should be recognised by the HTTP stream wrapper regardless of whitespace
|
|
// Transfer-Encoding:Chunked
|
|
do_test(0);
|
|
echo "\n";
|
|
// Transfer-Encoding: Chunked
|
|
do_test(1);
|
|
echo "\n";
|
|
// Transfer-Encoding: Chunked
|
|
do_test(2);
|
|
echo "\n";
|
|
// Trailing space at end of header
|
|
do_test(1, true);
|
|
echo "\n";
|
|
|
|
?>
|
|
--EXPECT--
|
|
Type='text/plain'
|
|
Hello
|
|
Size=5
|
|
World
|
|
|
|
Type='text/plain'
|
|
Hello
|
|
Size=5
|
|
World
|
|
|
|
Type='text/plain'
|
|
Hello
|
|
Size=5
|
|
World
|
|
|
|
Type='text/plain'
|
|
Hello
|
|
Size=5
|
|
World
|