mirror of
https://github.com/phpv8/v8js.git
synced 2024-12-31 22:31:52 +00:00
Fix tests/exception_propagation_2.phpt
The test relied on weird behaviour that PHP exceptions shouldn't stop JavaScript code execution. Since JavaScript execution is now stopped, the JavaScript catch handler is not executed anymore.
This commit is contained in:
parent
829a98e064
commit
c033000aea
@ -1,7 +1,6 @@
|
|||||||
--TEST--
|
--TEST--
|
||||||
Test V8::executeString() : Exception propagation test 2
|
Test V8::executeString() : Exception propagation test 2
|
||||||
--SKIPIF--
|
--SKIPIF--
|
||||||
SKIP needs discussion, see issue #144
|
|
||||||
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
|
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
|
||||||
--FILE--
|
--FILE--
|
||||||
<?php
|
<?php
|
||||||
@ -15,6 +14,9 @@ class Foo {
|
|||||||
$this->v8->foo = $this;
|
$this->v8->foo = $this;
|
||||||
$this->v8->executeString('fooobar', 'throw_0');
|
$this->v8->executeString('fooobar', 'throw_0');
|
||||||
var_dump($this->v8->getPendingException());
|
var_dump($this->v8->getPendingException());
|
||||||
|
// the exception is not cleared before the next executeString call,
|
||||||
|
// hence the next *exiting* executeString will throw.
|
||||||
|
// In this case this is the executeString call in bar() function.
|
||||||
$this->v8->executeString('try { PHP.foo.bar(); } catch (e) { print(e + " caught!\n"); }', 'trycatch1');
|
$this->v8->executeString('try { PHP.foo.bar(); } catch (e) { print(e + " caught!\n"); }', 'trycatch1');
|
||||||
$this->v8->executeString('try { PHP.foo.bar(); } catch (e) { print(e + " caught!\n"); }', 'trycatch2');
|
$this->v8->executeString('try { PHP.foo.bar(); } catch (e) { print(e + " caught!\n"); }', 'trycatch2');
|
||||||
}
|
}
|
||||||
@ -22,6 +24,8 @@ class Foo {
|
|||||||
public function bar()
|
public function bar()
|
||||||
{
|
{
|
||||||
echo "To Bar!\n";
|
echo "To Bar!\n";
|
||||||
|
// This executeString call throws a PHP exception, not propagated
|
||||||
|
// to JS, hence immediately triggering the top-level catch handler.
|
||||||
$this->v8->executeString('throw new Error();', 'throw_1');
|
$this->v8->executeString('throw new Error();', 'throw_1');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -72,7 +76,7 @@ object(V8JsScriptException)#%d (13) {
|
|||||||
["file"]=>
|
["file"]=>
|
||||||
string(%d) "%s"
|
string(%d) "%s"
|
||||||
["line"]=>
|
["line"]=>
|
||||||
int(24)
|
int(29)
|
||||||
["function"]=>
|
["function"]=>
|
||||||
string(11) "__construct"
|
string(11) "__construct"
|
||||||
["class"]=>
|
["class"]=>
|
||||||
@ -101,6 +105,5 @@ object(V8JsScriptException)#%d (13) {
|
|||||||
at throw_0:1:1"
|
at throw_0:1:1"
|
||||||
}
|
}
|
||||||
To Bar!
|
To Bar!
|
||||||
Error caught!
|
|
||||||
PHP Exception: throw_0:1: ReferenceError: fooobar is not defined
|
PHP Exception: throw_0:1: ReferenceError: fooobar is not defined
|
||||||
===EOF===
|
===EOF===
|
||||||
|
Loading…
Reference in New Issue
Block a user