From 86c04b13346f6ef48a57b34827e15368808a7c55 Mon Sep 17 00:00:00 2001 From: Kirk McKelvey Date: Mon, 22 Jun 2020 16:24:01 -0400 Subject: [PATCH 1/3] use rest param syntax to capture all git args --- src/runner/index.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/runner/index.ts b/src/runner/index.ts index 05d1fe9c1..b13c9f78a 100644 --- a/src/runner/index.ts +++ b/src/runner/index.ts @@ -74,7 +74,7 @@ function runCommand( * @param {promise} options.getStdinFn - used for mocking only */ export default async function run( - [, , hookName = '', HUSKY_GIT_PARAMS]: string[], + [, , hookName = '', ...HUSKY_GIT_PARAMS]: string[], { cwd = process.cwd() }: { cwd?: string } = {} ): Promise { const oldCommand = getOldCommand(cwd, hookName) @@ -83,8 +83,8 @@ export default async function run( // Add HUSKY_GIT_PARAMS to env const env: Env = {} - if (HUSKY_GIT_PARAMS) { - env.HUSKY_GIT_PARAMS = HUSKY_GIT_PARAMS + if (HUSKY_GIT_PARAMS?.length) { + env.HUSKY_GIT_PARAMS = HUSKY_GIT_PARAMS.join(' ') } if (command) { From cd5122ac75cd8cc6b14add158b82a29faeb5b3ca Mon Sep 17 00:00:00 2001 From: Kirk McKelvey Date: Mon, 22 Jun 2020 16:26:06 -0400 Subject: [PATCH 2/3] stop non-portable quote-grouping of git args --- sh/husky.sh | 2 +- src/installer/__tests__/__snapshots__/scripts.ts.snap | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/sh/husky.sh b/sh/husky.sh index f1542073f..c29bfbcf5 100644 --- a/sh/husky.sh +++ b/sh/husky.sh @@ -10,7 +10,7 @@ command_exists () { run_command () { if command_exists "$1"; then - "$@" husky-run $hookName "$gitParams" + "$@" husky-run $hookName $gitParams exitCode="$?" debug "$* husky-run exited with $exitCode exit code" diff --git a/src/installer/__tests__/__snapshots__/scripts.ts.snap b/src/installer/__tests__/__snapshots__/scripts.ts.snap index dd5d15345..50da308f3 100644 --- a/src/installer/__tests__/__snapshots__/scripts.ts.snap +++ b/src/installer/__tests__/__snapshots__/scripts.ts.snap @@ -39,7 +39,7 @@ command_exists () { run_command () { if command_exists \\"$1\\"; then - \\"$@\\" husky-run $hookName \\"$gitParams\\" + \\"$@\\" husky-run $hookName $gitParams exitCode=\\"$?\\" debug \\"$* husky-run exited with $exitCode exit code\\" From e9bfce54ed17f2e22f2a37f26bfd4bba30066914 Mon Sep 17 00:00:00 2001 From: Kirk McKelvey Date: Mon, 27 Jul 2020 11:02:43 -0400 Subject: [PATCH 3/3] ensure run() captures all arguments --- src/runner/__tests__/index.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/runner/__tests__/index.ts b/src/runner/__tests__/index.ts index 729d6fab3..ea418c956 100644 --- a/src/runner/__tests__/index.ts +++ b/src/runner/__tests__/index.ts @@ -138,8 +138,7 @@ describe('run', (): void => { }) ) - // 'commit-msg' takes one parameter from git - const status = await index(['', '', 'commit-msg', 'git fake param'], { + const status = await index(['', '', 'commit-msg', 'git', 'fake', 'param'], { cwd: dir, }) expectSpawnSyncToHaveBeenCalledWith(dir, 'echo success', {