contextify: throw timeout error properly
authorFedor Indutny <fedor@indutny.com>
Thu, 12 Jun 2014 22:40:28 +0000 (15:40 -0700)
committerFedor Indutny <fedor@indutny.com>
Fri, 13 Jun 2014 01:30:41 +0000 (18:30 -0700)
fix #7509

src/node_contextify.cc
test/simple/test-vm-timeout-rethrow.js [new file with mode: 0644]

index 3937fd6..9525e7d 100644 (file)
@@ -655,6 +655,7 @@ class ContextifyScript : public BaseObject {
     if (try_catch.HasCaught() && try_catch.HasTerminated()) {
       V8::CancelTerminateExecution(env->isolate());
       env->ThrowError("Script execution timed out.");
+      try_catch.ReThrow();
       return false;
     }
 
diff --git a/test/simple/test-vm-timeout-rethrow.js b/test/simple/test-vm-timeout-rethrow.js
new file mode 100644 (file)
index 0000000..c2158a1
--- /dev/null
@@ -0,0 +1,48 @@
+// Copyright Joyent, Inc. and other Node contributors.
+//
+// Permission is hereby granted, free of charge, to any person obtaining a
+// copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to permit
+// persons to whom the Software is furnished to do so, subject to the
+// following conditions:
+//
+// The above copyright notice and this permission notice shall be included
+// in all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
+// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
+// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
+// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
+// USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+var assert = require('assert');
+var vm = require('vm');
+var spawn = require('child_process').spawn;
+
+if (process.argv[2] === 'child') {
+  var code = 'var j = 0;\n' +
+      'for (var i = 0; i < 1000000; i++) j += add(i, i + 1);\n'
+      'j;';
+
+  var ctx = vm.createContext({
+    add: function(x, y) {
+      return x + y;
+    }
+  });
+
+  vm.runInContext(code, ctx, { timeout: 1 });
+} else {
+  var proc = spawn(process.execPath, process.argv.slice(1).concat('child'));
+  var err = '';
+  proc.stderr.on('data', function(data) {
+    err += data;
+  });
+
+  process.on('exit', function() {
+    assert.ok(/Script execution timed out/.test(err));
+  });
+}