mirror of
https://github.com/php/php-src.git
synced 2024-09-25 20:07:26 +00:00
a9512af810
Squashed commit of the following: commitbdd3b6895c
Author: Dmitry Stogov <dmitry@zend.com> Date: Thu Jun 16 00:19:42 2016 +0300 Fixed GOTO VM commit2f1d7c8b89
Author: Dmitry Stogov <dmitry@zend.com> Date: Wed Jun 15 21:01:57 2016 +0300 Removed unused variable commitcf749c42b0
Author: Dmitry Stogov <dmitry@zend.com> Date: Wed Jun 15 19:06:16 2016 +0300 Protection from $this reassign through mb_parse_str() commit59a9a6c83c
Author: Dmitry Stogov <dmitry@zend.com> Date: Wed Jun 15 18:14:50 2016 +0300 Added type inference rule for FETCH_THIS opcode commit73f8d14a85
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. commitfa0881381e
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". commite32cc528c0
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(). commit41f1531b52
Author: Dmitry Stogov <dmitry@zend.com> Date: Mon May 23 22:18:36 2016 +0300 Fixed inconsistent $this behavior
79 lines
1.6 KiB
PHP
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==
|