diff options
author | Xinchen Hui <laruence@php.net> | 2013-09-02 16:02:59 +0800 |
---|---|---|
committer | Xinchen Hui <laruence@php.net> | 2013-09-02 16:02:59 +0800 |
commit | dd1cbd140b513f5d790c2d8b57f48717e6864ef1 (patch) | |
tree | a91091f50f532a288b8550e7d454d42485a30e5c | |
parent | c8b0da6ef74100b476379ba40367c30564da6582 (diff) | |
parent | ed038d2ee330f827e24dc865ec8963175c1bfc2e (diff) | |
download | php-git-dd1cbd140b513f5d790c2d8b57f48717e6864ef1.tar.gz |
Merge branch 'PHP-5.4' into PHP-5.5
-rw-r--r-- | Zend/tests/bug64896.phpt | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/Zend/tests/bug64896.phpt b/Zend/tests/bug64896.phpt new file mode 100644 index 0000000000..e3e9f05632 --- /dev/null +++ b/Zend/tests/bug64896.phpt @@ -0,0 +1,47 @@ +--TEST-- +Bug #64896 (Segfault with gc_collect_cycles using unserialize on certain objects) +--XFAIL-- +We can not fix this bug with a significant (performace slow down) change to gc +--FILE-- +<?php +$bar = NULL; +class bad +{ + private $_private = array(); + + public function __construct() + { + $this->_private[] = 'php'; + } + + public function __destruct() + { + global $bar; + $bar = $this; + } +} + +$foo = new stdclass; +$foo->foo = $foo; +$foo->bad = new bad; + +gc_disable(); + +unserialize(serialize($foo)); +gc_collect_cycles(); +var_dump($bar); +/* will output: +object(bad)#4 (1) { + ["_private":"bad":private]=> + &UNKNOWN:0 +} +*/ +?> +--EXPECTF-- +bject(bad)#%d (1) { + ["_private":"bad":private]=> + array(1) { + [0]=> + string(3) "php" + } +} |