From 632c0c837099ca32524e8ef3212dfb55ec8b62a7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Th=C3=A9o=20Crevon?= Date: Wed, 21 Aug 2024 13:09:37 +0200 Subject: [PATCH] Fix cloud command not listed in k6 command's help text (#3901) * Fix `cloud` command not listed in k6 command's help text When implementing the new cloud command structure, we marked the k6 cloud command as deprecated by setting the cobra.Cmd Deprecated option. By doing so, Cobra took over itself to hide the command all in all from the help text's output, and users couldn't see the cloud command as part of the "Available Commands". This commit removes the Cobra.Cmd Deprecated option usage, and ports the message to the Long version of the help text. This commit also rephrases the message to be more accurate. Considering the cloud command itself is not deprecated, but rather its existing behavior, we have mentioned the original behavior consisting in taking a test resource as input is deprecated, specifically. * Add a root command test asserting the expected commands are available This commit adds a test asserting the root command help text lists the expected commands as available. --- cmd/cloud.go | 13 ++++--- cmd/root_test.go | 90 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 96 insertions(+), 7 deletions(-) create mode 100644 cmd/root_test.go diff --git a/cmd/cloud.go b/cmd/cloud.go index 9f529bd7064..bfb79015563 100644 --- a/cmd/cloud.go +++ b/cmd/cloud.go @@ -366,16 +366,15 @@ func getCmdCloud(gs *state.GlobalState) *cobra.Command { cloudCmd := &cobra.Command{ Use: "cloud", Short: "Run a test on the cloud", - Long: `Run a test in the Grafana Cloud k6. + Long: `The original behavior of the "k6 cloud" command described below is deprecated. +In future versions, the "cloud" command will only display a help text and will no longer run tests +in Grafana Cloud k6. To continue running tests in the cloud, please transition to using the "k6 cloud run" command. + +Run a test in the Grafana Cloud k6. This will archive test script(s), including all necessary resources, and execute the test in the Grafana Cloud k6 service. Be sure to run the "k6 cloud login" command prior to authenticate with Grafana Cloud k6.`, - Args: exactCloudArgs(), - Deprecated: `the k6 team is in the process of modifying and deprecating the "k6 cloud" command behavior. -In the future, the "cloud" command will only display a help text, instead of running tests in the Grafana Cloud k6. - -To run tests in the cloud, users are now invited to migrate to the "k6 cloud run" command instead. -`, + Args: exactCloudArgs(), PreRunE: c.preRun, RunE: c.run, Example: exampleText, diff --git a/cmd/root_test.go b/cmd/root_test.go new file mode 100644 index 00000000000..44e52790d41 --- /dev/null +++ b/cmd/root_test.go @@ -0,0 +1,90 @@ +package cmd + +import ( + "testing" + + "github.com/stretchr/testify/assert" + "go.k6.io/k6/cmd/tests" + "go.k6.io/k6/errext/exitcodes" +) + +func TestRootCommandHelpDisplayCommands(t *testing.T) { + t.Parallel() + + testCases := []struct { + name string + extraArgs []string + wantExitCode exitcodes.ExitCode + wantStdoutContains string + wantStdoutNotContains string + }{ + { + name: "should have archive command", + wantStdoutContains: " archive Create an archive", + }, + { + name: "should have cloud command", + wantStdoutContains: " cloud Run a test on the cloud", + }, + { + name: "should have completion command", + wantStdoutContains: " completion Generate the autocompletion script for the specified shell", + }, + { + name: "should have help command", + wantStdoutContains: " help Help about any command", + }, + { + name: "should have inspect command", + wantStdoutContains: " inspect Inspect a script or archive", + }, + { + name: "should have new command", + wantStdoutContains: " new Create and initialize a new k6 script", + }, + { + name: "should have pause command", + wantStdoutContains: " pause Pause a running test", + }, + { + name: "should have resume command", + wantStdoutContains: " resume Resume a paused test", + }, + { + name: "should have run command", + wantStdoutContains: " run Start a test", + }, + { + name: "should have scale command", + wantStdoutContains: " scale Scale a running test", + }, + { + name: "should have stats command", + wantStdoutContains: " stats Show test metrics", + }, + { + name: "should have status command", + wantStdoutContains: " status Show test status", + }, + { + name: "should have version command", + wantStdoutContains: " version Show application version", + }, + } + + for _, tc := range testCases { + tc := tc + + t.Run(tc.name, func(t *testing.T) { + t.Parallel() + + ts := tests.NewGlobalTestState(t) + ts.CmdArgs = []string{"k6", "help"} + newRootCommand(ts.GlobalState).execute() + + if tc.wantStdoutContains != "" { + assert.Contains(t, ts.Stdout.String(), tc.wantStdoutContains) + } + }) + } +}