diff --git a/lib/child_process.js b/lib/child_process.js index 8b29132cb4efdf..bc1a909fdc4562 100644 --- a/lib/child_process.js +++ b/lib/child_process.js @@ -967,6 +967,7 @@ function normalizeSpawnArguments(file /*, args, options*/) { else if (!util.isObject(options)) throw new TypeError('options argument must be an object'); + options = util._extend({}, options); args.unshift(file); var env = options.env || process.env; diff --git a/test/common.js b/test/common.js index 783d82a873befc..478e2e92a595ed 100644 --- a/test/common.js +++ b/test/common.js @@ -99,6 +99,17 @@ exports.spawnCat = function(options) { }; +exports.spawnSyncCat = function(options) { + var spawnSync = require('child_process').spawnSync; + + if (process.platform === 'win32') { + return spawnSync('more', [], options); + } else { + return spawnSync('cat', [], options); + } +}; + + exports.spawnPwd = function(options) { var spawn = require('child_process').spawn; diff --git a/test/simple/test-child-process-stdio.js b/test/simple/test-child-process-stdio.js index 32da15f5f5c8f5..ec59138db78e3f 100644 --- a/test/simple/test-child-process-stdio.js +++ b/test/simple/test-child-process-stdio.js @@ -34,3 +34,7 @@ child = common.spawnPwd(options); assert.equal(child.stdout, null); assert.equal(child.stderr, null); + +options = {stdio: 'ignore'}; +child = common.spawnSyncCat(options); +assert.deepEqual(options, {stdio: 'ignore'});