mirror of https://github.com/lukechilds/node.git
Browse Source
This commit increases code coverage related to the stdout and stderr outputs of the child_process exec() functions. Previously, stdout was completely covered, but stderr was not. PR-URL: https://github.com/nodejs/node/pull/10919 Reviewed-By: Sam Roberts <vieuxtech@gmail.com> Reviewed-By: Rich Trott <rtrott@gmail.com> Reviewed-By: Santiago Gimeno <santiago.gimeno@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>v6.x
cjihrig
8 years ago
committed by
Myles Borins
2 changed files with 49 additions and 24 deletions
@ -1,24 +0,0 @@ |
|||
'use strict'; |
|||
const common = require('../common'); |
|||
const assert = require('assert'); |
|||
const exec = require('child_process').exec; |
|||
const os = require('os'); |
|||
const str = 'hello'; |
|||
|
|||
// default encoding
|
|||
exec('echo ' + str, common.mustCall(function(err, stdout, stderr) { |
|||
assert.strictEqual(typeof stdout, 'string', 'Expected stdout to be a string'); |
|||
assert.strictEqual(typeof stderr, 'string', 'Expected stderr to be a string'); |
|||
assert.strictEqual(str + os.EOL, stdout); |
|||
})); |
|||
|
|||
// no encoding (Buffers expected)
|
|||
exec('echo ' + str, { |
|||
encoding: null |
|||
}, common.mustCall(function(err, stdout, stderr) { |
|||
assert.strictEqual(stdout instanceof Buffer, true, |
|||
'Expected stdout to be a Buffer'); |
|||
assert.strictEqual(stderr instanceof Buffer, true, |
|||
'Expected stderr to be a Buffer'); |
|||
assert.strictEqual(str + os.EOL, stdout.toString()); |
|||
})); |
@ -0,0 +1,49 @@ |
|||
'use strict'; |
|||
const common = require('../common'); |
|||
const assert = require('assert'); |
|||
const cp = require('child_process'); |
|||
const stdoutData = 'foo'; |
|||
const stderrData = 'bar'; |
|||
const expectedStdout = `${stdoutData}\n`; |
|||
const expectedStderr = `${stderrData}\n`; |
|||
|
|||
if (process.argv[2] === 'child') { |
|||
// The following console calls are part of the test.
|
|||
console.log(stdoutData); |
|||
console.error(stderrData); |
|||
} else { |
|||
function run(options, callback) { |
|||
const cmd = `${process.execPath} ${__filename} child`; |
|||
|
|||
cp.exec(cmd, options, common.mustCall((err, stdout, stderr) => { |
|||
assert.ifError(err); |
|||
callback(stdout, stderr); |
|||
})); |
|||
} |
|||
|
|||
// Test default encoding, which should be utf8.
|
|||
run({}, (stdout, stderr) => { |
|||
assert.strictEqual(typeof stdout, 'string'); |
|||
assert.strictEqual(typeof stderr, 'string'); |
|||
assert.strictEqual(stdout, expectedStdout); |
|||
assert.strictEqual(stderr, expectedStderr); |
|||
}); |
|||
|
|||
// Test explicit utf8 encoding.
|
|||
run({ encoding: 'utf8' }, (stdout, stderr) => { |
|||
assert.strictEqual(typeof stdout, 'string'); |
|||
assert.strictEqual(typeof stderr, 'string'); |
|||
assert.strictEqual(stdout, expectedStdout); |
|||
assert.strictEqual(stderr, expectedStderr); |
|||
}); |
|||
|
|||
// Test cases that result in buffer encodings.
|
|||
[undefined, null, 'buffer', 'invalid'].forEach((encoding) => { |
|||
run({ encoding }, (stdout, stderr) => { |
|||
assert(stdout instanceof Buffer); |
|||
assert(stdout instanceof Buffer); |
|||
assert.strictEqual(stdout.toString(), expectedStdout); |
|||
assert.strictEqual(stderr.toString(), expectedStderr); |
|||
}); |
|||
}); |
|||
} |
Loading…
Reference in new issue