forked from php/php-src
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Fixed bug #61371 (resource leak). This bug had two parts, a long st…
…anding leak already fixed in trunk/5.3 and now merged onto 5.4 and a leak introduced in fixing bug #61115. This better fix for #61115 fixes the leak (the inhibition for deleting the context was too broad) and so prevents segfaults in new circumstances (where the inhibition was not broad enough).
- Loading branch information
1 parent
a07759a
commit ef19fba
Showing
5 changed files
with
64 additions
and
1 deletion.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
--TEST-- | ||
Bug #61115: Stream related segfault on fatal error in php_stream_context_del_link - variation 1 | ||
--FILE-- | ||
<?php | ||
|
||
$fileResourceTemp = fopen('php://temp', 'wr'); | ||
stream_context_get_options($fileResourceTemp); | ||
ftruncate($fileResourceTemp, PHP_INT_MAX); | ||
?> | ||
--EXPECTF-- | ||
Fatal error: Allowed memory size of %d bytes exhausted at %s:%d (tried to allocate %d bytes) in %s on line %d |
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,10 @@ | ||
--TEST-- | ||
Bug #61115: Stream related segfault on fatal error in php_stream_context_del_link - variation 2 | ||
--FILE-- | ||
<?php | ||
stream_socket_client('abc', $var, $var, 0, STREAM_CLIENT_PERSISTENT); | ||
|
||
?> | ||
==DONE== | ||
--EXPECT-- | ||
==DONE== |
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,40 @@ | ||
--TEST-- | ||
Bug #61371: stream_context_create() causes memory leaks on use streams_socket_create | ||
--FILE-- | ||
<?php | ||
function test($doFclose) { | ||
$previous = null; | ||
$current = null; | ||
for($test=1;$test<=3;$test++) { | ||
$current = memory_get_usage(true); | ||
if (!is_null($previous)) { | ||
var_dump($previous == $current); | ||
} | ||
$previous = $current; | ||
echo 'memory: '.round($current / 1024, 0)."kb\n"; | ||
for($i=0;$i<=100;$i++) { | ||
$context = stream_context_create(array()); | ||
$stream = stream_socket_client('udp://0.0.0.0:80', $errno, $errstr, 10, STREAM_CLIENT_CONNECT, $context); | ||
if ($doFclose) fclose($stream); | ||
unset($context); | ||
unset($stream); | ||
unset($errno); | ||
unset($errstr); | ||
} | ||
} | ||
} | ||
|
||
test(true); | ||
test(false); | ||
?> | ||
--EXPECTF-- | ||
memory: %dkb | ||
bool(true) | ||
memory: %dkb | ||
bool(true) | ||
memory: %dkb | ||
memory: %dkb | ||
bool(true) | ||
memory: %dkb | ||
bool(true) | ||
memory: %dkb |
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