2014-12-07 15:05:58 +00:00
|
|
|
--TEST--
|
|
|
|
Test V8::setTimeLimit() : Time limit can be changed
|
|
|
|
--SKIPIF--
|
2016-03-26 10:47:58 +00:00
|
|
|
<?php
|
|
|
|
require_once(dirname(__FILE__) . '/skipif.inc');
|
|
|
|
|
|
|
|
if (getenv("SKIP_SLOW_TESTS")) {
|
|
|
|
die("skip slow test");
|
|
|
|
}
|
|
|
|
?>
|
2014-12-07 15:05:58 +00:00
|
|
|
--FILE--
|
|
|
|
<?php
|
|
|
|
|
|
|
|
$JS = <<< EOT
|
|
|
|
var jsfunc = function() {
|
|
|
|
PHP.incrTimeLimit();
|
2014-12-08 22:43:04 +00:00
|
|
|
var start = (new Date()).getTime();
|
|
|
|
|
2014-12-07 15:05:58 +00:00
|
|
|
var text = "abcdefghijklmnopqrstuvwyxz0123456789";
|
2016-01-06 16:23:22 +00:00
|
|
|
while ((new Date()).getTime() - start < 800) {
|
|
|
|
/* pass at least 800ms in the loop so the timer loop has plenty of
|
2014-12-08 22:43:04 +00:00
|
|
|
* time to trigger. */
|
2014-12-07 15:05:58 +00:00
|
|
|
var encoded = encodeURI(text);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
jsfunc;
|
|
|
|
EOT;
|
|
|
|
|
|
|
|
$v8 = new V8Js();
|
2014-12-08 22:43:04 +00:00
|
|
|
/* Set very short time limit, but enough so v8 can start up safely. */
|
2016-01-06 16:23:22 +00:00
|
|
|
$v8->setTimeLimit(200);
|
2014-12-07 15:05:58 +00:00
|
|
|
|
|
|
|
$v8->incrTimeLimit = function() use ($v8) {
|
2016-01-06 16:23:22 +00:00
|
|
|
$v8->setTimeLimit(500);
|
2014-12-07 15:05:58 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
$func = $v8->executeString($JS);
|
|
|
|
var_dump($func);
|
|
|
|
|
|
|
|
try {
|
|
|
|
$func();
|
|
|
|
} catch (V8JsTimeLimitException $e) {
|
|
|
|
print get_class($e); print PHP_EOL;
|
|
|
|
print $e->getMessage(); print PHP_EOL;
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
===EOF===
|
|
|
|
--EXPECTF--
|
|
|
|
object(V8Function)#%d (0) {
|
|
|
|
}
|
|
|
|
V8JsTimeLimitException
|
2016-01-06 16:23:22 +00:00
|
|
|
Script time limit of 500 milliseconds exceeded
|
2014-12-07 15:05:58 +00:00
|
|
|
===EOF===
|