diff --git a/src/node.js b/src/node.js index cb50341ce2ea8c..065c337e743993 100644 --- a/src/node.js +++ b/src/node.js @@ -558,8 +558,13 @@ 'return require("vm").runInThisContext(' + JSON.stringify(body) + ', { filename: ' + JSON.stringify(name) + ' });\n'; - var result = module._compile(script, name + '-wrapper'); - if (process._print_eval) console.log(result); + // Defer evaluation for a tick. This is a workaround for deferred + // events not firing when evaluating scripts from the command line, + // see https://github.com/nodejs/io.js/issues/1600. + process.nextTick(function() { + var result = module._compile(script, name + '-wrapper'); + if (process._print_eval) console.log(result); + }); } function createWritableStdioStream(fd) { diff --git a/test/message/eval_messages.out b/test/message/eval_messages.out index 809e788f7a4603..be2120ce795a95 100644 --- a/test/message/eval_messages.out +++ b/test/message/eval_messages.out @@ -6,9 +6,9 @@ SyntaxError: Strict mode code may not include a with statement at Object.exports.runInThisContext (vm.js:*) at Object. ([eval]-wrapper:*:*) at Module._compile (module.js:*:*) - at evalScript (node.js:*:*) - at startup (node.js:*:*) at node.js:*:* + at doNTCallback0 (node.js:*:*) + at process._tickCallback (node.js:*:*) 42 42 [eval]:1 @@ -19,9 +19,9 @@ Error: hello at Object.exports.runInThisContext (vm.js:*) at Object. ([eval]-wrapper:*:*) at Module._compile (module.js:*:*) - at evalScript (node.js:*:*) - at startup (node.js:*:*) at node.js:*:* + at doNTCallback0 (node.js:*:*) + at process._tickCallback (node.js:*:*) [eval]:1 throw new Error("hello") ^ @@ -30,9 +30,9 @@ Error: hello at Object.exports.runInThisContext (vm.js:*) at Object. ([eval]-wrapper:*:*) at Module._compile (module.js:*:*) - at evalScript (node.js:*:*) - at startup (node.js:*:*) at node.js:*:* + at doNTCallback0 (node.js:*:*) + at process._tickCallback (node.js:*:*) 100 [eval]:1 var x = 100; y = x; @@ -42,9 +42,9 @@ ReferenceError: y is not defined at Object.exports.runInThisContext (vm.js:*) at Object. ([eval]-wrapper:*:*) at Module._compile (module.js:*:*) - at evalScript (node.js:*:*) - at startup (node.js:*:*) at node.js:*:* + at doNTCallback0 (node.js:*:*) + at process._tickCallback (node.js:*:*) [eval]:1 var ______________________________________________; throw 10 ^ diff --git a/test/message/stdin_messages.out b/test/message/stdin_messages.out index 92d09a0a144428..9dc6451d1c3379 100644 --- a/test/message/stdin_messages.out +++ b/test/message/stdin_messages.out @@ -7,12 +7,8 @@ SyntaxError: Strict mode code may not include a with statement at Object.exports.runInThisContext (vm.js:*) at Object. ([stdin]-wrapper:*:*) at Module._compile (module.js:*:*) - at evalScript (node.js:*:*) - at Socket. (node.js:*:*) - at emitNone (events.js:*:*) - at Socket.emit (events.js:*:*) - at endReadableNT (_stream_readable.js:*:*) - at doNTCallback2 (node.js:*:*) + at node.js:*:* + at doNTCallback0 (node.js:*:*) at process._tickCallback (node.js:*:*) 42 42 @@ -25,12 +21,9 @@ Error: hello at Object.exports.runInThisContext (vm.js:*) at Object. ([stdin]-wrapper:*:*) at Module._compile (module.js:*:*) - at evalScript (node.js:*:*) - at Socket. (node.js:*:*) - at emitNone (events.js:*:*) - at Socket.emit (events.js:*:*) - at endReadableNT (_stream_readable.js:*:*) - at doNTCallback2 (node.js:*:*) + at node.js:*:* + at doNTCallback0 (node.js:*:*) + at process._tickCallback (node.js:*:*) [stdin]:1 throw new Error("hello") @@ -40,12 +33,9 @@ Error: hello at Object.exports.runInThisContext (vm.js:*) at Object. ([stdin]-wrapper:*:*) at Module._compile (module.js:*:*) - at evalScript (node.js:*:*) - at Socket. (node.js:*:*) - at emitNone (events.js:*:*) - at Socket.emit (events.js:*:*) - at endReadableNT (_stream_readable.js:*:*) - at doNTCallback2 (node.js:*:*) + at node.js:*:* + at doNTCallback0 (node.js:*:*) + at process._tickCallback (node.js:*:*) 100 [stdin]:1 @@ -56,12 +46,9 @@ ReferenceError: y is not defined at Object.exports.runInThisContext (vm.js:*) at Object. ([stdin]-wrapper:*:*) at Module._compile (module.js:*:*) - at evalScript (node.js:*:*) - at Socket. (node.js:*:*) - at emitNone (events.js:*:*) - at Socket.emit (events.js:*:*) - at endReadableNT (_stream_readable.js:*:*) - at doNTCallback2 (node.js:*:*) + at node.js:*:* + at doNTCallback0 (node.js:*:*) + at process._tickCallback (node.js:*:*) [stdin]:1 var ______________________________________________; throw 10 diff --git a/test/parallel/test-cli-eval-event.js b/test/parallel/test-cli-eval-event.js new file mode 100644 index 00000000000000..b19bdd38680f79 --- /dev/null +++ b/test/parallel/test-cli-eval-event.js @@ -0,0 +1,15 @@ +'use strict'; + +const common = require('../common'); +const assert = require('assert'); +const spawn = require('child_process').spawn; + +const child = spawn(process.execPath, ['-e', ` + const server = require('net').createServer().listen(0); + server.once('listening', server.close); +`]); + +child.once('exit', common.mustCall(function(exitCode, signalCode) { + assert.equal(exitCode, 0); + assert.equal(signalCode, null); +}));