mirror of https://github.com/lukechilds/node.git
Browse Source
This commit adds coverage for the timeout option used by child_process exec() and execFile(). PR-URL: https://github.com/nodejs/node/pull/9208 Reviewed-By: Santiago Gimeno <santiago.gimeno@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Michaël Zasso <targos@protonmail.com>v7.x
cjihrig
8 years ago
committed by
Evan Lucas
1 changed files with 45 additions and 0 deletions
@ -0,0 +1,45 @@ |
|||||
|
'use strict'; |
||||
|
const common = require('../common'); |
||||
|
const assert = require('assert'); |
||||
|
const cp = require('child_process'); |
||||
|
|
||||
|
if (process.argv[2] === 'child') { |
||||
|
setTimeout(() => { |
||||
|
// The following console statements are part of the test.
|
||||
|
console.log('child stdout'); |
||||
|
console.error('child stderr'); |
||||
|
}, common.platformTimeout(1000)); |
||||
|
return; |
||||
|
} |
||||
|
|
||||
|
const cmd = `${process.execPath} ${__filename} child`; |
||||
|
|
||||
|
// Test the case where a timeout is set, and it expires.
|
||||
|
cp.exec(cmd, { timeout: 1 }, common.mustCall((err, stdout, stderr) => { |
||||
|
assert.strictEqual(err.killed, true); |
||||
|
assert.strictEqual(err.code, null); |
||||
|
assert.strictEqual(err.signal, 'SIGTERM'); |
||||
|
assert.strictEqual(err.cmd, cmd); |
||||
|
assert.strictEqual(stdout.trim(), ''); |
||||
|
assert.strictEqual(stderr.trim(), ''); |
||||
|
})); |
||||
|
|
||||
|
// Test with a different kill signal.
|
||||
|
cp.exec(cmd, { |
||||
|
timeout: 1, |
||||
|
killSignal: 'SIGKILL' |
||||
|
}, common.mustCall((err, stdout, stderr) => { |
||||
|
assert.strictEqual(err.killed, true); |
||||
|
assert.strictEqual(err.code, null); |
||||
|
assert.strictEqual(err.signal, 'SIGKILL'); |
||||
|
assert.strictEqual(err.cmd, cmd); |
||||
|
assert.strictEqual(stdout.trim(), ''); |
||||
|
assert.strictEqual(stderr.trim(), ''); |
||||
|
})); |
||||
|
|
||||
|
// Test the case where a timeout is set, but not expired.
|
||||
|
cp.exec(cmd, { timeout: 2 ** 30 }, common.mustCall((err, stdout, stderr) => { |
||||
|
assert.ifError(err); |
||||
|
assert.strictEqual(stdout.trim(), 'child stdout'); |
||||
|
assert.strictEqual(stderr.trim(), 'child stderr'); |
||||
|
})); |
Loading…
Reference in new issue