From 830de786d2a7e139edd373488501c773d6e416df Mon Sep 17 00:00:00 2001 From: Julien Duchesne Date: Fri, 2 Feb 2024 11:10:52 -0500 Subject: [PATCH] Fix tests Bringing in features from https://github.com/grafana/grizzly/pull/325 --- integration/context_test.go | 6 +++--- integration/dashboard_test.go | 6 +++--- integration/utils_test.go | 11 ++++++++--- 3 files changed, 14 insertions(+), 9 deletions(-) diff --git a/integration/context_test.go b/integration/context_test.go index 73bf407a..a4fa6267 100644 --- a/integration/context_test.go +++ b/integration/context_test.go @@ -12,9 +12,9 @@ func TestContexts(t *testing.T) { TestDir: "testdata/contexts", Commands: []Command{ { - Command: "config get-contexts", - ExpectedCode: 0, - ExpectedOutput: "get-contexts.txt", + Command: "config get-contexts", + ExpectedCode: 0, + ExpectedOutputFile: "get-contexts.txt", }, }, }) diff --git a/integration/dashboard_test.go b/integration/dashboard_test.go index e0e78ef2..0941f779 100644 --- a/integration/dashboard_test.go +++ b/integration/dashboard_test.go @@ -14,9 +14,9 @@ func TestDashboard(t *testing.T) { RunOnContexts: allContexts, Commands: []Command{ { - Command: "get Dashboard.ReciqtgGk", - ExpectedCode: 0, - ExpectedOutput: "ReciqtgGk.json", + Command: "get Dashboard.ReciqtgGk", + ExpectedCode: 0, + ExpectedOutputFile: "ReciqtgGk.json", }, }, }) diff --git a/integration/utils_test.go b/integration/utils_test.go index 9e03d1f8..4016e5d7 100644 --- a/integration/utils_test.go +++ b/integration/utils_test.go @@ -18,6 +18,7 @@ type Command struct { ExpectedCode int ExpectedError error ExpectedOutput string + ExpectedOutputFile string ExpectedOutputContains string } type GrizzlyTest struct { @@ -46,10 +47,14 @@ func runTest(t *testing.T, test GrizzlyTest) { require.Error(t, err, command.ExpectedError) } require.Equal(t, command.ExpectedCode, exitCode, "Exited with %d (%d expected).\nOutput: %s\nstderr: %s", exitCode, command.ExpectedCode, stdout, stderr) - if command.ExpectedOutput != "" { - data, err := os.ReadFile(filepath.Join(test.TestDir, command.ExpectedOutput)) + // Check stdout + if command.ExpectedOutputFile != "" { + bytes, err := os.ReadFile(filepath.Join(test.TestDir, command.ExpectedOutputFile)) require.NoError(t, err) - require.Equal(t, string(data), stdout) + command.ExpectedOutput = string(bytes) + } + if command.ExpectedOutput != "" { + require.Equal(t, command.ExpectedOutput, stdout) } if command.ExpectedOutputContains != "" { require.Contains(t, stdout, command.ExpectedOutputContains)