summaryrefslogtreecommitdiff
path: root/tests/classes/__call_005.phpt
diff options
context:
space:
mode:
Diffstat (limited to 'tests/classes/__call_005.phpt')
-rw-r--r--tests/classes/__call_005.phpt37
1 files changed, 37 insertions, 0 deletions
diff --git a/tests/classes/__call_005.phpt b/tests/classes/__call_005.phpt
new file mode 100644
index 0000000..6e15848
--- /dev/null
+++ b/tests/classes/__call_005.phpt
@@ -0,0 +1,37 @@
+--TEST--
+When __call() is invoked via ::, ensure private implementation of __call() in superclass is accessed without error.
+--FILE--
+<?php
+class A {
+ private function __call($strMethod, $arrArgs) {
+ echo "In " . __METHOD__ . "($strMethod, array(" . implode(',',$arrArgs) . "))\n";
+ var_dump($this);
+ }
+}
+
+class B extends A {
+ function test() {
+ A::test1(1,'a');
+ B::test2(1,'a');
+ self::test3(1,'a');
+ parent::test4(1,'a');
+ }
+}
+
+$b = new B();
+$b->test();
+?>
+--EXPECTF--
+Warning: The magic method __call() must have public visibility and cannot be static in %s__call_005.php on line 3
+In A::__call(test1, array(1,a))
+object(B)#1 (0) {
+}
+In A::__call(test2, array(1,a))
+object(B)#1 (0) {
+}
+In A::__call(test3, array(1,a))
+object(B)#1 (0) {
+}
+In A::__call(test4, array(1,a))
+object(B)#1 (0) {
+}