0
0
mirror of https://github.com/nodejs/node.git synced 2024-12-01 16:10:02 +01:00
nodejs/test/parallel/test-sigint-infinite-loop.js
Gibson Fahnestock 7a0e462f9f test: use eslint to fix var->const/let
Manually fix issues that eslint --fix couldn't do automatically.

PR-URL: https://github.com/nodejs/node/pull/10685
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Roman Reiss <me@silverwind.io>
2017-01-11 11:43:52 +00:00

35 lines
950 B
JavaScript

'use strict';
// This test is to assert that we can SIGINT a script which loops forever.
// Ref(http):
// groups.google.com/group/nodejs-dev/browse_thread/thread/e20f2f8df0296d3f
const common = require('../common');
const assert = require('assert');
const spawn = require('child_process').spawn;
console.log('start');
const c = spawn(process.execPath, ['-e', 'while(true) { console.log("hi"); }']);
let sentKill = false;
c.stdout.on('data', function(s) {
// Prevent race condition:
// Wait for the first bit of output from the child process
// so that we're sure that it's in the V8 event loop and not
// just in the startup phase of execution.
if (!sentKill) {
c.kill('SIGINT');
console.log('SIGINT infinite-loop.js');
sentKill = true;
}
});
c.on('exit', common.mustCall(function(code) {
assert.ok(code !== 0);
console.log('killed infinite-loop.js');
}));
process.on('exit', function() {
assert.ok(sentKill);
});