summaryrefslogtreecommitdiff
path: root/ext/standard/tests/http/bug69337.phpt
blob: f7595eb746bd563caac91c1aeb85b530d25182ce (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
--TEST--
Bug #69337 (Stream context leaks when http request fails)
--SKIPIF--
<?php require 'server.inc'; http_server_skipif('tcp://127.0.0.1:22345'); ?>
--INI--
allow_url_fopen=1
allow_url_include=1
--FILE--
<?php
require 'server.inc';

function stream_notification_callback($notification_code, $severity, $message, $message_code, $bytes_transferred, $bytes_max)
{
	if($notification_code == STREAM_NOTIFY_REDIRECTED) {
	  // $http_response_header is now a string, but will be used as an array
     // by php_stream_url_wrap_http_ex() later on
       $GLOBALS['http_response_header'] = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\0\0\0\0";
    }
}

$ctx = stream_context_create();
stream_context_set_params($ctx, array("notification" => "stream_notification_callback"));

$responses = array(
	"data://text/plain,HTTP/1.0 302 Found\r\nLocation: http://127.0.0.1:22345/try-again\r\n\r\n",
	"data://text/plain,HTTP/1.0 404 Not Found\r\n\r\n",
);

$pid = http_server("tcp://127.0.0.1:22345", $responses, $output);

$f = file_get_contents('http://127.0.0.1:22345/', 0, $ctx);

http_server_kill($pid);
var_dump($f);
?>
==DONE==
--EXPECTF--
string(26) "HTTP/1.0 404 Not Found

"
==DONE==