php-src/tests/classes/__call_007.phpt
Dmitry Stogov a9512af810 Implemented RFC: Fix inconsistent behavior of $this variable
Squashed commit of the following:

commit bdd3b6895c
Author: Dmitry Stogov <dmitry@zend.com>
Date:   Thu Jun 16 00:19:42 2016 +0300

    Fixed GOTO VM

commit 2f1d7c8b89
Author: Dmitry Stogov <dmitry@zend.com>
Date:   Wed Jun 15 21:01:57 2016 +0300

    Removed unused variable

commit cf749c42b0
Author: Dmitry Stogov <dmitry@zend.com>
Date:   Wed Jun 15 19:06:16 2016 +0300

    Protection from $this reassign through mb_parse_str()

commit 59a9a6c83c
Author: Dmitry Stogov <dmitry@zend.com>
Date:   Wed Jun 15 18:14:50 2016 +0300

    Added type inference rule for FETCH_THIS opcode

commit 73f8d14a85
Author: Dmitry Stogov <dmitry@zend.com>
Date:   Wed Jun 15 18:11:18 2016 +0300

    Restored PHP-7 behavior of isset($this->foo).
    It throws exception if not in object context.
    Removed useless opcode handlers.

commit fa0881381e
Author: Dmitry Stogov <dmitry@zend.com>
Date:   Tue May 31 12:25:47 2016 +0300

    Changed "Notice: Undefined variable: this" into "Exception: Using $this when not in object context".

commit e32cc528c0
Author: Dmitry Stogov <dmitry@zend.com>
Date:   Tue May 24 02:02:43 2016 +0300

    Throw exception on attempt to re-assign $this through extract() and parse_str().

commit 41f1531b52
Author: Dmitry Stogov <dmitry@zend.com>
Date:   Mon May 23 22:18:36 2016 +0300

    Fixed inconsistent $this behavior
2016-06-16 02:30:23 +03:00

79 lines
1.6 KiB
PHP

--TEST--
Ensure exceptions are handled properly when thrown in a statically declared __call.
--FILE--
<?php
class A {
static function __call($strMethod, $arrArgs) {
@var_dump($this);
throw new Exception;
echo "You should not see this";
}
function test() {
A::unknownCalledWithSRO(1,2,3);
}
}
class B extends A {
function test() {
B::unknownCalledWithSROFromChild(1,2,3);
}
}
$a = new A();
echo "---> Invoke __call via simple method call.\n";
try {
$a->unknown();
} catch (Exception $e) {
echo "Exception caught OK; continuing.\n";
}
echo "\n\n---> Invoke __call via scope resolution operator within instance.\n";
try {
$a->test();
} catch (Exception $e) {
echo "Exception caught OK; continuing.\n";
}
echo "\n\n---> Invoke __call via scope resolution operator within child instance.\n";
$b = new B();
try {
$b->test();
} catch (Exception $e) {
echo "Exception caught OK; continuing.\n";
}
echo "\n\n---> Invoke __call via callback.\n";
try {
call_user_func(array($b, 'unknownCallback'), 1,2,3);
} catch (Exception $e) {
echo "Exception caught OK; continuing.\n";
}
?>
==DONE==
--EXPECTF--
Warning: The magic method __call() must have public visibility and cannot be static in %s on line 3
---> Invoke __call via simple method call.
object(A)#1 (0) {
}
Exception caught OK; continuing.
---> Invoke __call via scope resolution operator within instance.
object(A)#1 (0) {
}
Exception caught OK; continuing.
---> Invoke __call via scope resolution operator within child instance.
object(B)#2 (0) {
}
Exception caught OK; continuing.
---> Invoke __call via callback.
object(B)#2 (0) {
}
Exception caught OK; continuing.
==DONE==