mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Merge pull request #23583 from anusha-ragunathan/accept-perms
Add accept-permissions flag for install.
This commit is contained in:
commit
6253c29494
3 changed files with 55 additions and 5 deletions
|
@ -13,21 +13,31 @@ import (
|
||||||
"golang.org/x/net/context"
|
"golang.org/x/net/context"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type pluginOptions struct {
|
||||||
|
name string
|
||||||
|
grantPerms bool
|
||||||
|
}
|
||||||
|
|
||||||
func newInstallCommand(dockerCli *client.DockerCli) *cobra.Command {
|
func newInstallCommand(dockerCli *client.DockerCli) *cobra.Command {
|
||||||
|
var options pluginOptions
|
||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "install",
|
Use: "install",
|
||||||
Short: "Install a plugin",
|
Short: "Install a plugin",
|
||||||
Args: cli.RequiresMinArgs(1), // TODO: allow for set args
|
Args: cli.RequiresMinArgs(1), // TODO: allow for set args
|
||||||
RunE: func(cmd *cobra.Command, args []string) error {
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
return runInstall(dockerCli, args[0], args[1:])
|
options.name = args[0]
|
||||||
|
return runInstall(dockerCli, options)
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
flags := cmd.Flags()
|
||||||
|
flags.BoolVar(&options.grantPerms, "grant-all-permissions", true, "grant all permissions necessary to run the plugin")
|
||||||
|
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
func runInstall(dockerCli *client.DockerCli, name string, args []string) error {
|
func runInstall(dockerCli *client.DockerCli, options pluginOptions) error {
|
||||||
named, err := reference.ParseNamed(name) // FIXME: validate
|
named, err := reference.ParseNamed(options.name) // FIXME: validate
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -46,6 +56,6 @@ func runInstall(dockerCli *client.DockerCli, name string, args []string) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
// TODO: pass acceptAllPermissions and noEnable flag
|
// TODO: pass noEnable flag
|
||||||
return dockerCli.Client().PluginInstall(ctx, ref.String(), encodedAuth, false, false, dockerCli.In(), dockerCli.Out())
|
return dockerCli.Client().PluginInstall(ctx, ref.String(), encodedAuth, options.grantPerms, false, dockerCli.In(), dockerCli.Out())
|
||||||
}
|
}
|
||||||
|
|
36
integration-cli/docker_cli_plugins_test.go
Normal file
36
integration-cli/docker_cli_plugins_test.go
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/docker/docker/pkg/integration/checker"
|
||||||
|
"github.com/go-check/check"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (s *DockerSuite) TestPluginBasicOps(c *check.C) {
|
||||||
|
testRequires(c, DaemonIsLinux, ExperimentalDaemon)
|
||||||
|
name := "tiborvass/no-remove"
|
||||||
|
tag := "latest"
|
||||||
|
nameWithTag := name + ":" + tag
|
||||||
|
|
||||||
|
_, _, err := dockerCmdWithError("plugin", "install", name)
|
||||||
|
c.Assert(err, checker.IsNil)
|
||||||
|
|
||||||
|
out, _, err := dockerCmdWithError("plugin", "ls")
|
||||||
|
c.Assert(err, checker.IsNil)
|
||||||
|
c.Assert(out, checker.Contains, name)
|
||||||
|
c.Assert(out, checker.Contains, tag)
|
||||||
|
c.Assert(out, checker.Contains, "true")
|
||||||
|
|
||||||
|
out, _, err = dockerCmdWithError("plugin", "inspect", nameWithTag)
|
||||||
|
c.Assert(err, checker.IsNil)
|
||||||
|
c.Assert(out, checker.Contains, "A test plugin for Docker")
|
||||||
|
|
||||||
|
out, _, err = dockerCmdWithError("plugin", "remove", nameWithTag)
|
||||||
|
c.Assert(out, checker.Contains, "is active")
|
||||||
|
|
||||||
|
_, _, err = dockerCmdWithError("plugin", "disable", nameWithTag)
|
||||||
|
c.Assert(err, checker.IsNil)
|
||||||
|
|
||||||
|
out, _, err = dockerCmdWithError("plugin", "remove", nameWithTag)
|
||||||
|
c.Assert(err, checker.IsNil)
|
||||||
|
c.Assert(out, checker.Contains, nameWithTag)
|
||||||
|
}
|
|
@ -30,6 +30,10 @@ var (
|
||||||
func() bool { return daemonPlatform == "linux" },
|
func() bool { return daemonPlatform == "linux" },
|
||||||
"Test requires a Linux daemon",
|
"Test requires a Linux daemon",
|
||||||
}
|
}
|
||||||
|
ExperimentalDaemon = testRequirement{
|
||||||
|
func() bool { return utils.ExperimentalBuild() },
|
||||||
|
"Test requires an experimental daemon",
|
||||||
|
}
|
||||||
NotExperimentalDaemon = testRequirement{
|
NotExperimentalDaemon = testRequirement{
|
||||||
func() bool { return !utils.ExperimentalBuild() },
|
func() bool { return !utils.ExperimentalBuild() },
|
||||||
"Test requires a non experimental daemon",
|
"Test requires a non experimental daemon",
|
||||||
|
|
Loading…
Add table
Reference in a new issue