set_time_limit_002.phpt 808 B

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