diff --git a/command.go b/command.go index a8b0fa5..0b74c2d 100644 --- a/command.go +++ b/command.go @@ -684,6 +684,7 @@ func (c *Command) ExecuteC() (cmd *Command, err error) { } func (c *Command) initHelpFlag() { + c.mergePersistentFlags() if c.Flags().Lookup("help") == nil { c.Flags().BoolP("help", "h", false, "help for "+c.Name()) } diff --git a/command_test.go b/command_test.go index 127ca0e..3d10ba8 100644 --- a/command_test.go +++ b/command_test.go @@ -134,6 +134,21 @@ func Test_DisableFlagParsing(t *testing.T) { } } +func TestInitHelpFlagMergesFlags(t *testing.T) { + usage := "custom flag" + baseCmd := Command{Use: "testcmd"} + baseCmd.PersistentFlags().Bool("help", false, usage) + cmd := Command{Use: "do"} + baseCmd.AddCommand(&cmd) + + cmd.initHelpFlag() + actual := cmd.Flags().Lookup("help").Usage + if actual != usage { + t.Fatalf("Expected the help flag from the base command with usage '%s', " + + "but got the default with usage '%s'", usage, actual) + } +} + func TestCommandsAreSorted(t *testing.T) { EnableCommandSorting = true