]> granicus.if.org Git - php/commitdiff
- MFB
authorMarcus Boerger <helly@php.net>
Fri, 16 Dec 2005 23:11:00 +0000 (23:11 +0000)
committerMarcus Boerger <helly@php.net>
Fri, 16 Dec 2005 23:11:00 +0000 (23:11 +0000)
Zend/tests/bug29210.phpt
Zend/tests/bug32290.phpt

index 294685499c6d2f77595f3a3e4a96f41d59ed2d23..16e6e6db162dbd914fe44beb1480c855c0fc240f 100644 (file)
@@ -89,10 +89,14 @@ if (is_callable(array('test_class','test_func4'))) {
 $object = new foo();
 $object->test();
 ?>
---EXPECT--
+--EXPECTF--
 test_func1
 test_func2
+
+Strict Standards: Non-static method test_class::test_func3() canot be called statically, assuming $this from compatible context test_class in %sbug29210.php on line %d
 test_func3
+
+Strict Standards: Non-static method test_class::test_func4() canot be called statically, assuming $this from compatible context test_class in %sbug29210.php on line %d
 test_func4
 test_func1 isn't callable from outside
 test_func2 isn't callable from outside
@@ -100,5 +104,9 @@ test_func3 isn't callable from outside
 test_func4 isn't callable from outside
 test_func1 isn't callable from child
 test_func2
+
+Strict Standards: Non-static method test_class::test_func3() canot be called statically, assuming $this from compatible context foo in %sbug29210.php on line %d
 test_func3 isn't callable from child
+
+Strict Standards: Non-static method test_class::test_func4() canot be called statically, assuming $this from compatible context foo in %sbug29210.php on line %d
 test_func4
index bfd3f518ed92b0cc4e99c610775a660976800601..6038da54ba174862bf260766bc613fddcc393180 100755 (executable)
@@ -3,17 +3,35 @@ Bug #32290 (calling call_user_func_array() ends in infinite loop within child cl
 --FILE--
 <?php
 
-function my_error_handler($errno, $errstr, $errfile, $errline) {
-       var_dump($errstr);
-}
-
-set_error_handler('my_error_handler');
-
 class TestA
 {
        public function doSomething($i)
        {
-               echo __METHOD__ . "($this)\n";
+               echo __METHOD__ . "($i)\n";
+               return --$i;
+       }
+
+       public function doSomethingThis($i)
+       {
+               echo __METHOD__ . "($i)\n";
+               return --$i;
+       }
+
+       public function doSomethingParent($i)
+       {
+               echo __METHOD__ . "($i)\n";
+               return --$i;
+       }
+
+       public function doSomethingParentThis($i)
+       {
+               echo __METHOD__ . "($i)\n";
+               return --$i;
+       }
+
+       public static function doSomethingStatic($i)
+       {
+               echo __METHOD__ . "($i)\n";
                return --$i;
        }
 }
@@ -22,22 +40,87 @@ class TestB extends TestA
 {
        public function doSomething($i)
        {
-               echo __METHOD__ . "($this)\n";
+               echo __METHOD__ . "($i)\n";
                $i++;
                if ($i >= 5) return 5;
-               return call_user_func_array(array("TestA","doSomething"), array($i));
+               return call_user_func_array(array("TestA", "doSomething"), array($i));
+       }
+
+       public function doSomethingThis($i)
+       {
+               echo __METHOD__ . "($i)\n";
+               $i++;
+               if ($i >= 5) return 5;
+               return call_user_func_array(array($this, "TestA::doSomethingThis"), array($i));
+       }
+
+       public function doSomethingParent($i)
+       {
+               echo __METHOD__ . "($i)\n";
+               $i++;
+               if ($i >= 5) return 5;
+               return call_user_func_array(array("parent", "doSomethingParent"), array($i));
+       }
+
+       public function doSomethingParentThis($i)
+       {
+               echo __METHOD__ . "($i)\n";
+               $i++;
+               if ($i >= 5) return 5;
+               return call_user_func_array(array($this, "parent::doSomethingParentThis"), array($i));
+       }
+
+       public static function doSomethingStatic($i)
+       {
+               echo __METHOD__ . "($i)\n";
+               $i++;
+               if ($i >= 5) return 5;
+               return call_user_func_array(array("TestA", "doSomethingStatic"), array($i));
        }
 }
 
 $x = new TestB();
+echo "===A===\n";
 var_dump($x->doSomething(1));
+echo "\n===B===\n";
+var_dump($x->doSomethingThis(1));
+echo "\n===C===\n";
+var_dump($x->doSomethingParent(1));
+echo "\n===D===\n";
+var_dump($x->doSomethingParentThis(1));
+echo "\n===E===\n";
+var_dump($x->doSomethingStatic(1));
 
 ?>
 ===DONE===
+<?php exit(0); ?>
 --EXPECTF--
-string(54) "Object of class TestB could not be converted to string"
-TestB::doSomething()
-string(54) "Object of class TestB could not be converted to string"
-TestA::doSomething()
+===A===
+TestB::doSomething(1)
+
+Strict Standards: Non-static method TestA::doSomething() canot be called statically, assuming $this from compatible context TestB in %sbug32290.php on line %d
+TestA::doSomething(2)
+int(1)
+
+===B===
+TestB::doSomethingThis(1)
+TestA::doSomethingThis(2)
+int(1)
+
+===C===
+TestB::doSomethingParent(1)
+
+Strict Standards: Non-static method TestA::doSomethingParent() canot be called statically, assuming $this from compatible context TestB in %sbug32290.php on line %d
+TestA::doSomethingParent(2)
+int(1)
+
+===D===
+TestB::doSomethingParentThis(1)
+TestA::doSomethingParentThis(2)
+int(1)
+
+===E===
+TestB::doSomethingStatic(1)
+TestA::doSomethingStatic(2)
 int(1)
 ===DONE===