diff --git a/command.go b/command.go index dbb2c298..140fbfdf 100644 --- a/command.go +++ b/command.go @@ -1296,6 +1296,11 @@ Simply type ` + c.DisplayName() + ` help [path to command] for full details.`, c.Printf("Unknown help topic %#q\n", args) CheckErr(c.Root().Usage()) } else { + // FLow the context down to be used in help text + if cmd.ctx == nil { + cmd.ctx = c.ctx + } + cmd.InitDefaultHelpFlag() // make possible 'help' flag to be shown cmd.InitDefaultVersionFlag() // make possible 'version' flag to be shown CheckErr(cmd.Help()) diff --git a/command_test.go b/command_test.go index 7e7c3418..156df9eb 100644 --- a/command_test.go +++ b/command_test.go @@ -2921,3 +2921,34 @@ func TestUnknownFlagShouldReturnSameErrorRegardlessOfArgPosition(t *testing.T) { }) } } + +func TestHelpFuncExecuted(t *testing.T) { + helpText := "Long description" + + // Create a context that will be unique, not just the background context + //nolint:golint,staticcheck // We can safely use a basic type as key in tests. + executionCtx := context.WithValue(context.Background(), "testKey", "123") + + child := &Command{Use: "child", Run: emptyRun} + child.SetHelpFunc(func(cmd *Command, args []string) { + _, err := cmd.OutOrStdout().Write([]byte(helpText)) + if err != nil { + t.Error(err) + } + + // Test for https://github.com/spf13/cobra/issues/2240 + if cmd.Context() != executionCtx { + t.Error("Context doesn't equal the execution context") + } + }) + + rootCmd := &Command{Use: "root", Run: emptyRun} + rootCmd.AddCommand(child) + + output, err := executeCommandWithContext(executionCtx, rootCmd, "help", "child") + if err != nil { + t.Errorf("Unexpected error: %v", err) + } + + checkStringContains(t, output, helpText) +}