From a428249a54553eb36c41ef402f44a4ff0c291d41 Mon Sep 17 00:00:00 2001 From: Yanis Benson Date: Tue, 7 May 2019 10:35:11 +0300 Subject: [PATCH] Fix non-executable execution with `input` option (#212) --- index.js | 3 ++- test.js | 4 ++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/index.js b/index.js index bb635fadf8..6261c3abfd 100644 --- a/index.js +++ b/index.js @@ -107,7 +107,8 @@ function handleArgs(command, args, options = {}) { } function handleInput(spawned, input) { - if (input === undefined) { + // Checking for stdin is workaround for https://github.com/nodejs/node/issues/26852 on Node.js 10 and 12 + if (input === undefined || spawned.stdin === undefined) { return; } diff --git a/test.js b/test.js index 2c7e017dd1..abbf7d77c8 100644 --- a/test.js +++ b/test.js @@ -336,6 +336,10 @@ if (process.platform !== 'win32') { const cp = execa('non-executable'); await t.throwsAsync(cp); }); + + test('execa() rejects with correct error and doesn\'t throw if running non-executable with input', async t => { + await t.throwsAsync(execa('non-executable', {input: 'Hey!'}), /EACCES/); + }); } test('error.killed is true if process was killed directly', async t => {