From 6bcf51b7ee84b97d81662c2698ad9fb5858da886 Mon Sep 17 00:00:00 2001 From: Ian Campbell Date: Tue, 11 Dec 2018 14:52:59 +0000 Subject: [PATCH] =?UTF-8?q?Integrate=20CLI=20plugins=20with=20`docker=20he?= =?UTF-8?q?lp=20=C2=ABfoo=C2=BB`?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Ian Campbell --- cli-plugins/manager/manager.go | 4 ++++ cli/cobra.go | 13 +++++++++++ e2e/cli-plugins/run_test.go | 41 ++++++++++++++++++++++++++++++++++ 3 files changed, 58 insertions(+) diff --git a/cli-plugins/manager/manager.go b/cli-plugins/manager/manager.go index 79e3b6f08922..6bcea880c494 100644 --- a/cli-plugins/manager/manager.go +++ b/cli-plugins/manager/manager.go @@ -183,3 +183,7 @@ func PluginRunCommand(name string, rootcmd *cobra.Command) (*exec.Cmd, error) { // they lack e.g. global options which we must propagate here. return runPluginCommand(name, rootcmd, os.Args[1:]) } + +func PluginHelpCommand(name string, rootcmd *cobra.Command) (*exec.Cmd, error) { + return runPluginCommand(name, rootcmd, []string{"help", name}) +} diff --git a/cli/cobra.go b/cli/cobra.go index 3a8755e0d302..04c9f3b36076 100644 --- a/cli/cobra.go +++ b/cli/cobra.go @@ -2,6 +2,7 @@ package cli import ( "fmt" + "os" "strings" pluginmanager "github.com/docker/cli/cli-plugins/manager" @@ -57,6 +58,18 @@ var helpCommand = &cobra.Command{ RunE: func(c *cobra.Command, args []string) error { cmd, args, e := c.Root().Find(args) if cmd == nil || e != nil || len(args) > 0 { + if len(args) == 1 { + helpcmd, err := pluginmanager.PluginHelpCommand(args[0], cmd.Root()) + if err == nil { + helpcmd.Stdin = os.Stdin + helpcmd.Stdout = os.Stdout + helpcmd.Stderr = os.Stderr + return helpcmd.Run() + } + if _, ok := err.(pluginmanager.ErrPluginNotFound); !ok { + return err + } + } return errors.Errorf("unknown help topic: %v", strings.Join(args, " ")) } diff --git a/e2e/cli-plugins/run_test.go b/e2e/cli-plugins/run_test.go index c7c9ad06ed68..5e45d404e2d1 100644 --- a/e2e/cli-plugins/run_test.go +++ b/e2e/cli-plugins/run_test.go @@ -18,6 +18,20 @@ func TestRunNonexisting(t *testing.T) { }) } +func TestHelpNonexisting(t *testing.T) { + res := icmd.RunCmd(icmd.Command("docker", "help", "nonexistent")) + res.Assert(t, icmd.Expected{ + ExitCode: 1, + Err: "unknown help topic: nonexistent", + }) + + res = icmd.RunCmd(icmd.Command("docker", "nonexistent", "--help")) + res.Assert(t, icmd.Expected{ + ExitCode: 0, + Out: "Usage: docker [OPTIONS] COMMAND", + }) +} + func TestRunBad(t *testing.T) { res := icmd.RunCmd(icmd.Command("docker", "badmeta")) res.Assert(t, icmd.Expected{ @@ -26,6 +40,20 @@ func TestRunBad(t *testing.T) { }) } +func TestHelpBad(t *testing.T) { + res := icmd.RunCmd(icmd.Command("docker", "help", "badmeta")) + res.Assert(t, icmd.Expected{ + ExitCode: 1, + Err: "unknown help topic: badmeta", + }) + + res = icmd.RunCmd(icmd.Command("docker", "badmeta", "--help")) + res.Assert(t, icmd.Expected{ + ExitCode: 0, + Out: "Usage: docker [OPTIONS] COMMAND", + }) +} + func TestRunGood(t *testing.T) { res := icmd.RunCmd(icmd.Command("docker", "helloworld")) res.Assert(t, icmd.Expected{ @@ -33,3 +61,16 @@ func TestRunGood(t *testing.T) { Out: "Hello World!", }) } + +func TestHelpGood(t *testing.T) { + res := icmd.RunCmd(icmd.Command("docker", "help", "helloworld")) + res.Assert(t, icmd.Expected{ + ExitCode: 0, + Out: "Usage: docker helloworld", + }) + res = icmd.RunCmd(icmd.Command("docker", "helloworld", "--help")) + res.Assert(t, icmd.Expected{ + ExitCode: 0, + Out: "Usage: docker helloworld", + }) +}