diff options
author | Jakub Zelenka <bukka@php.net> | 2016-08-28 13:00:49 +0100 |
---|---|---|
committer | Jakub Zelenka <bukka@php.net> | 2016-08-29 14:49:40 +0100 |
commit | 27acbcf4df1ddac593f37fc4f9bb30fdfb456377 (patch) | |
tree | dec719acc01d667e77375f3cbcb64584469b9601 | |
parent | df05dbb3dfa0b55b25ff499c7e1646928279952d (diff) | |
download | php-git-27acbcf4df1ddac593f37fc4f9bb30fdfb456377.tar.gz |
Add test for fixed bug #68992
-rw-r--r-- | ext/json/tests/bug68992.phpt | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/ext/json/tests/bug68992.phpt b/ext/json/tests/bug68992.phpt new file mode 100644 index 0000000000..0fc41eca49 --- /dev/null +++ b/ext/json/tests/bug68992.phpt @@ -0,0 +1,30 @@ +--TEST-- +Bug #68992 (json_encode stacks exceptions thrown by JsonSerializable classes) +--SKIPIF-- +<?php +if (!extension_loaded('json')) die('skip'); +?> +--FILE-- +<?php + +class MyClass implements JsonSerializable { + public function jsonSerialize() { + throw new Exception('Not implemented!'); + } +} +$classes = []; +for($i = 0; $i < 5; $i++) { + $classes[] = new MyClass(); +} + +try { + json_encode($classes); +} catch(Exception $e) { + do { + printf("%s (%d) [%s]\n", $e->getMessage(), $e->getCode(), get_class($e)); + } while ($e = $e->getPrevious()); +} +?> +--EXPECT-- +Failed calling MyClass::jsonSerialize() (0) [Exception] +Not implemented! (0) [Exception] |