summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorMarco Pivetta <ocramius@gmail.com>2013-06-20 10:34:45 +0200
committerStanislav Malyshev <stas@php.net>2013-06-23 13:53:46 -0700
commitf1e37d03c117317f543d9ff68ea8e3e23da077bd (patch)
tree969a2ade8aed0df9d160078d30e7535c86babcaa /tests
parent61fb822d1a474d475d3e608ba60541d5b79029cf (diff)
downloadphp-git-f1e37d03c117317f543d9ff68ea8e3e23da077bd.tar.gz
Adding test to verify that __sleep can handle parent classes' private members
Diffstat (limited to 'tests')
-rw-r--r--tests/classes/private_members_serialization.phpt23
1 files changed, 23 insertions, 0 deletions
diff --git a/tests/classes/private_members_serialization.phpt b/tests/classes/private_members_serialization.phpt
new file mode 100644
index 0000000000..c8dd3ab248
--- /dev/null
+++ b/tests/classes/private_members_serialization.phpt
@@ -0,0 +1,23 @@
+--TEST--
+Verifies that it is possible to return private member names of parent classes in __sleep
+--FILE--
+<?php
+class foo
+{
+ private $private = 'private';
+ protected $protected = 'protected';
+ public $public = 'public';
+}
+
+class bar extends foo
+{
+ public function __sleep()
+ {
+ return array("\0foo\0private", 'protected', 'public');
+ }
+}
+
+var_dump(str_replace("\0", '\0', serialize(new bar())));
+?>
+--EXPECTF--
+string(114) "O:3:"bar":3:{s:12:"\0foo\0private";s:7:"private";s:12:"\0*\0protected";s:9:"protected";s:6:"public";s:6:"public";}"