From 2718d7491c28c7f0b43d016c1b25fb2a1b2463b5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Burak=20Yi=C4=9Fit=20Kaya?= Date: Mon, 9 Oct 2017 21:12:02 +0100 Subject: [PATCH] fix(config): Relay exit code when using yarn-path from yarnrc (#4669) **Summary** Follow up to #4204. We forgot to relay the exit code of the newly spawned yarn instance when using `yarn-path` which is causing false negatives especially when using `yarn run`. This patch relays the exit code of the spawned process. **Test plan** Added a new test that fails without the fix. --- __tests__/integration.js | 56 ++++++++++++++++++++++++++-------------- src/cli/index.js | 7 +++-- 2 files changed, 42 insertions(+), 21 deletions(-) diff --git a/__tests__/integration.js b/__tests__/integration.js index 53cdf15b5a..e8f864d081 100644 --- a/__tests__/integration.js +++ b/__tests__/integration.js @@ -250,30 +250,48 @@ test('yarnrc arguments', async () => { expect((await fs.stat(`${cwd}/yarn-cache`)).isDirectory()).toBe(true); }); -test('yarnrc binary path (js)', async () => { - const cwd = await makeTemp(); +describe('yarnrc path', () => { + test('js file', async () => { + const cwd = await makeTemp(); - await fs.writeFile(`${cwd}/.yarnrc`, 'yarn-path "./override.js"\n'); - await fs.writeFile(`${cwd}/override.js`, 'console.log("override called")\n'); + await fs.writeFile(`${cwd}/.yarnrc`, 'yarn-path "./override.js"\n'); + await fs.writeFile(`${cwd}/override.js`, 'console.log("override called")\n'); - const [stdoutOutput] = await runYarn([], {cwd}); - expect(stdoutOutput.toString().trim()).toEqual('override called'); -}); + const [stdoutOutput] = await runYarn([], {cwd}); + expect(stdoutOutput.toString().trim()).toEqual('override called'); + }); -test('yarnrc binary path (executable)', async () => { - const cwd = await makeTemp(); + test('executable file', async () => { + const cwd = await makeTemp(); - if (process.platform === 'win32') { - await fs.writeFile(`${cwd}/.yarnrc`, 'yarn-path "./override.cmd"\n'); - await fs.writeFile(`${cwd}/override.cmd`, '@echo override called\n'); - } else { - await fs.writeFile(`${cwd}/.yarnrc`, 'yarn-path "./override"\n'); - await fs.writeFile(`${cwd}/override`, '#!/usr/bin/env sh\necho override called\n'); - await fs.chmod(`${cwd}/override`, 0o755); - } + if (process.platform === 'win32') { + await fs.writeFile(`${cwd}/.yarnrc`, 'yarn-path "./override.cmd"\n'); + await fs.writeFile(`${cwd}/override.cmd`, '@echo override called\n'); + } else { + await fs.writeFile(`${cwd}/.yarnrc`, 'yarn-path "./override"\n'); + await fs.writeFile(`${cwd}/override`, '#!/usr/bin/env sh\necho override called\n'); + await fs.chmod(`${cwd}/override`, 0o755); + } + + const [stdoutOutput] = await runYarn([], {cwd}); + expect(stdoutOutput.toString().trim()).toEqual('override called'); + }); + + test('js file exit code', async () => { + const cwd = await makeTemp(); - const [stdoutOutput] = await runYarn([], {cwd}); - expect(stdoutOutput.toString().trim()).toEqual('override called'); + await fs.writeFile(`${cwd}/.yarnrc`, 'yarn-path "./override.js"\n'); + await fs.writeFile(`${cwd}/override.js`, 'process.exit(123);'); + + let error = false; + try { + await runYarn([], {cwd}); + } catch (err) { + error = err.code; + } + + expect(error).toEqual(123); + }); }); for (const withDoubleDash of [false, true]) { diff --git a/src/cli/index.js b/src/cli/index.js index 840558423d..4e52d09c58 100644 --- a/src/cli/index.js +++ b/src/cli/index.js @@ -544,15 +544,18 @@ async function start(): Promise { if (yarnPath && process.env.YARN_IGNORE_PATH !== '1') { const argv = process.argv.slice(2); const opts = {stdio: 'inherit', env: Object.assign({}, process.env, {YARN_IGNORE_PATH: 1})}; + let exitCode = 0; try { - await spawnp(yarnPath, argv, opts); + exitCode = await spawnp(yarnPath, argv, opts); } catch (firstError) { try { - await forkp(yarnPath, argv, opts); + exitCode = await forkp(yarnPath, argv, opts); } catch (error) { throw firstError; } + + process.exitCode = exitCode; } } else { // ignore all arguments after a --