From 765de1ae114375648b87da8c27ca1cbd59bbe5ea Mon Sep 17 00:00:00 2001 From: Robert Chiras Date: Thu, 19 May 2016 17:13:20 +0300 Subject: [PATCH] child_process: Check stderr before accessing it MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit If something bad happens in spawnSync, stderr might be null. Therefore, we have to check it before using it, so we won't mask the actual exception. PR-URL: https://github.com/nodejs/node/pull/6877 Reviewed-By: Colin Ihrig Reviewed-By: Robert Jefe Lindstädt Reviewed-By: James M Snell Reviewed-By: Ben Noordhuis Reviewed-By: Jeremiah Senkpiel --- lib/child_process.js | 4 ++-- test/sequential/test-child-process-execsync.js | 12 ++++++++++++ 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/lib/child_process.js b/lib/child_process.js index 003f6569fa0792..b6768c654ad592 100644 --- a/lib/child_process.js +++ b/lib/child_process.js @@ -494,7 +494,7 @@ function execFileSync(/*command, args, options*/) { var ret = spawnSync(opts.file, opts.args.slice(1), opts.options); - if (inheritStderr) + if (inheritStderr && ret.stderr) process.stderr.write(ret.stderr); var err = checkExecSyncError(ret); @@ -514,7 +514,7 @@ function execSync(command /*, options*/) { var ret = spawnSync(opts.file, opts.options); ret.cmd = command; - if (inheritStderr) + if (inheritStderr && ret.stderr) process.stderr.write(ret.stderr); var err = checkExecSyncError(ret); diff --git a/test/sequential/test-child-process-execsync.js b/test/sequential/test-child-process-execsync.js index fc3c0494dcbe18..e16fa32a400ffb 100644 --- a/test/sequential/test-child-process-execsync.js +++ b/test/sequential/test-child-process-execsync.js @@ -12,6 +12,18 @@ var start = Date.now(); var err; var caught = false; +// Verify that stderr is not accessed when a bad shell is used +assert.throws( + function() { execSync('exit -1', {shell: 'bad_shell'}); }, + /spawnSync bad_shell ENOENT/, + 'execSync did not throw the expected exception!' +); +assert.throws( + function() { execFileSync('exit -1', {shell: 'bad_shell'}); }, + /spawnSync bad_shell ENOENT/, + 'execFileSync did not throw the expected exception!' +); + try { var cmd = `"${process.execPath}" -e "setTimeout(function(){}, ${SLEEP});"`; var ret = execSync(cmd, {timeout: TIMER});