From efd475e2e292d68c170dc495360b0f389ddce335 Mon Sep 17 00:00:00 2001 From: Luke Massa Date: Mon, 11 Sep 2023 11:13:26 -0400 Subject: [PATCH] feat: add portability to command invocation unit tests (#3758) * Add portability to command invocation unit tests * Fix linting --- .../runtime/post_workflow_hook_runner_test.go | 7 +++-- .../runtime/pre_workflow_hook_runner_test.go | 27 +++++++++++++++++-- 2 files changed, 30 insertions(+), 4 deletions(-) diff --git a/server/core/runtime/post_workflow_hook_runner_test.go b/server/core/runtime/post_workflow_hook_runner_test.go index f4db6fcf93..bbf22b4394 100644 --- a/server/core/runtime/post_workflow_hook_runner_test.go +++ b/server/core/runtime/post_workflow_hook_runner_test.go @@ -1,6 +1,7 @@ package runtime_test import ( + "fmt" "strings" "testing" @@ -18,6 +19,8 @@ func TestPostWorkflowHookRunner_Run(t *testing.T) { defaultShell := "sh" defaultShellArgs := "-c" + defautShellCommandNotFoundErrorFormat := commandNotFoundErrorFormat(defaultShell) + defaultUnterminatedStringError := unterminatedStringError(defaultShell, defaultShellArgs) cases := []struct { Command string @@ -63,7 +66,7 @@ func TestPostWorkflowHookRunner_Run(t *testing.T) { Command: "echo 'a", Shell: defaultShell, ShellArgs: defaultShellArgs, - ExpOut: "sh: 1: Syntax error: Unterminated quoted string\r\n", + ExpOut: defaultUnterminatedStringError, ExpErr: "exit status 2: running \"sh -c echo 'a\" in", ExpDescription: "", }, @@ -79,7 +82,7 @@ func TestPostWorkflowHookRunner_Run(t *testing.T) { Command: "lkjlkj", Shell: defaultShell, ShellArgs: defaultShellArgs, - ExpOut: "sh: 1: lkjlkj: not found\r\n", + ExpOut: fmt.Sprintf(defautShellCommandNotFoundErrorFormat, "lkjlkj"), ExpErr: "exit status 127: running \"sh -c lkjlkj\" in", ExpDescription: "", }, diff --git a/server/core/runtime/pre_workflow_hook_runner_test.go b/server/core/runtime/pre_workflow_hook_runner_test.go index e51d49e58e..ad8659cfa2 100644 --- a/server/core/runtime/pre_workflow_hook_runner_test.go +++ b/server/core/runtime/pre_workflow_hook_runner_test.go @@ -1,6 +1,8 @@ package runtime_test import ( + "fmt" + goruntime "runtime" "strings" "testing" @@ -14,10 +16,31 @@ import ( . "github.com/runatlantis/atlantis/testing" ) +func commandNotFoundErrorFormat(shell string) string { + // TODO: Add more GOOSs. Also I haven't done too much testing + // maybe the output here depends on other factors as well + if goruntime.GOOS == "darwin" { + return fmt.Sprintf("%s: %%s: command not found\r\n", shell) + } + return fmt.Sprintf("%s: 1: %%s: not found\r\n", shell) + +} + +func unterminatedStringError(shell, shellArgs string) string { + // TODO: Add more GOOSs. Also I haven't done too much testing + // maybe the output here depends on other factors as well + if goruntime.GOOS == "darwin" { + return fmt.Sprintf("%s: %s: line 0: unexpected EOF while looking for matching `''\r\n%s: %s: line 1: syntax error: unexpected end of file\r\n", shell, shellArgs, shell, shellArgs) + } + return fmt.Sprintf("%s: 1: Syntax error: Unterminated quoted string\r\n", shell) +} + func TestPreWorkflowHookRunner_Run(t *testing.T) { defaultShell := "sh" defaultShellArgs := "-c" + defautShellCommandNotFoundErrorFormat := commandNotFoundErrorFormat(defaultShell) + defaultUnterminatedStringError := unterminatedStringError(defaultShell, defaultShellArgs) cases := []struct { Command string @@ -63,7 +86,7 @@ func TestPreWorkflowHookRunner_Run(t *testing.T) { Command: "echo 'a", Shell: defaultShell, ShellArgs: defaultShellArgs, - ExpOut: "sh: 1: Syntax error: Unterminated quoted string\r\n", + ExpOut: defaultUnterminatedStringError, ExpErr: "exit status 2: running \"sh -c echo 'a\" in", ExpDescription: "", }, @@ -79,7 +102,7 @@ func TestPreWorkflowHookRunner_Run(t *testing.T) { Command: "lkjlkj", Shell: defaultShell, ShellArgs: defaultShellArgs, - ExpOut: "sh: 1: lkjlkj: not found\r\n", + ExpOut: fmt.Sprintf(defautShellCommandNotFoundErrorFormat, "lkjlkj"), ExpErr: "exit status 127: running \"sh -c lkjlkj\" in", ExpDescription: "", },