set_time_limit_001.phpt 721 B

12345678910111213141516171819202122232425262728293031323334353637
  1. --TEST--
  2. Test V8::setTimeLimit() : Time limit applied to V8Function calls
  3. --SKIPIF--
  4. <?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
  5. --FILE--
  6. <?php
  7. $JS = <<< EOT
  8. var jsfunc = function() {
  9. var text = "abcdefghijklmnopqrstuvwyxz0123456789";
  10. for (var i = 0; i < 10000000; ++i) {
  11. var encoded = encodeURI(text);
  12. }
  13. };
  14. jsfunc;
  15. EOT;
  16. $v8 = new V8Js();
  17. $v8->setTimeLimit(100);
  18. $func = $v8->executeString($JS);
  19. var_dump($func);
  20. try {
  21. $func();
  22. } catch (V8JsTimeLimitException $e) {
  23. print get_class($e); print PHP_EOL;
  24. print $e->getMessage(); print PHP_EOL;
  25. }
  26. ?>
  27. ===EOF===
  28. --EXPECTF--
  29. object(V8Function)#%d (0) {
  30. }
  31. V8JsTimeLimitException
  32. Script time limit of 100 milliseconds exceeded
  33. ===EOF===