0
0
mirror of https://github.com/phpv8/v8js.git synced 2024-11-14 04:58:42 +00:00
phpv8/tests/set_time_limit_004.phpt
Stefan Siegl adb8288061 Make set_time_limit tests slower
... to reduce the risk of false positives on slower (or busier) boxes.
2016-01-06 17:23:22 +01:00

36 lines
803 B
PHP

--TEST--
Test V8::setTimeLimit() : Time limit can be prolonged
--SKIPIF--
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
--FILE--
<?php
$JS = <<< EOT
var text = "abcdefghijklmnopqrstuvwyxz0123456789";
/* Spend 75 * >10ms in the loop, i.e. at least 750ms; hence
* it should be killed if prolonging doesn't work. */
for (var j = 0; j < 30; ++j) {
PHP.prolongTimeLimit();
var start = (new Date()).getTime();
var encoded = encodeURI(text);
while ((new Date()).getTime() - start < 10) {
/* pass about 10ms in the loop, then prolong */
var encoded = encodeURI(text);
}
}
EOT;
$v8 = new V8Js();
$v8->setTimeLimit(300);
$v8->prolongTimeLimit = function() use ($v8) {
$v8->setTimeLimit(300);
};
$v8->executeString($JS);
?>
===EOF===
--EXPECTF--
===EOF===