summaryrefslogtreecommitdiff
path: root/ext/standard/tests/http/bug60570.phpt
blob: 3c16d780331361c23fc4dcaa0efe559da7f820bf (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
42
43
44
45
46
47
48
49
50
--TEST--
Bug #60570 (Stream context leaks when http request fails)
--SKIPIF--
<?php require 'server.inc'; http_server_skipif('tcp://127.0.0.1:12342'); ?>
--INI--
allow_url_fopen=1
--FILE--
<?php
require 'server.inc';

function do_test() {

    $responses = array(
        "data://text/plain,HTTP/1.0 404 Not Found\r\n\r\n",
        "data://text/plain,HTTP/1.0 404 Not Found\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:12342", $responses, $output);

    $a = $b = count(get_resources());

    $i = 3;
    while ($i--) {
        $context = stream_context_create(array('http'=>array('timeout'=>1)));
        file_get_contents('http://127.0.0.1:12342/', 0, $context);
        unset($context);

        $b = $a;
        $a = count(get_resources());
    }

    http_server_kill($pid);

    echo "leak? penultimate iteration: $b, last one: $a\n";
    var_dump($a == $b);
}

do_test();
--EXPECTF--
Warning: file_get_contents(http://127.0.0.1:12342/): Failed to open stream: HTTP request failed! HTTP/1.0 404 Not Found
 in %s on line %d

Warning: file_get_contents(http://127.0.0.1:12342/): Failed to open stream: HTTP request failed! HTTP/1.0 404 Not Found
 in %s on line %d

Warning: file_get_contents(http://127.0.0.1:12342/): Failed to open stream: HTTP request failed! HTTP/1.0 404 Not Found
 in %s on line %d
leak? penultimate iteration: %d, last one: %d
bool(true)