cli-plugins/manager: getPluginDirs: remove redundant error-return
This function returned an error (if any) from [config.Path]. However, the
only situation in which an error could be returned was if the given path
to append to `config.Dir` was outside of the config directory. This can
only happen if the path to append would try to traverse directories (e.g.,
passing `../../cli-plugins`).
Given that we're passing a hard-coded value, that would not be the case,
so we can simplify the code to join the path directly, and don't have to
handle errors.
[config.Path]: 2d74733942/cli/config/config.go (L100-L107)
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
This commit is contained in:
parent
d1a19d4476
commit
091421f13f
@ -64,10 +64,7 @@ func invokeAndCollectHooks(ctx context.Context, cfg *configfile.ConfigFile, root
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
pluginDirs, err := getPluginDirs(cfg)
|
pluginDirs := getPluginDirs(cfg)
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
nextSteps := make([]string, 0, len(pluginsCfg))
|
nextSteps := make([]string, 0, len(pluginsCfg))
|
||||||
for pluginName, pluginCfg := range pluginsCfg {
|
for pluginName, pluginCfg := range pluginsCfg {
|
||||||
match, ok := pluginMatch(pluginCfg, subCmdStr)
|
match, ok := pluginMatch(pluginCfg, subCmdStr)
|
||||||
|
@ -61,20 +61,16 @@ func IsNotFound(err error) bool {
|
|||||||
// 3. Platform-specific defaultSystemPluginDirs.
|
// 3. Platform-specific defaultSystemPluginDirs.
|
||||||
//
|
//
|
||||||
// [ConfigFile.CLIPluginsExtraDirs]: https://pkg.go.dev/github.com/docker/cli@v26.1.4+incompatible/cli/config/configfile#ConfigFile.CLIPluginsExtraDirs
|
// [ConfigFile.CLIPluginsExtraDirs]: https://pkg.go.dev/github.com/docker/cli@v26.1.4+incompatible/cli/config/configfile#ConfigFile.CLIPluginsExtraDirs
|
||||||
func getPluginDirs(cfg *configfile.ConfigFile) ([]string, error) {
|
func getPluginDirs(cfg *configfile.ConfigFile) []string {
|
||||||
var pluginDirs []string
|
var pluginDirs []string
|
||||||
|
|
||||||
if cfg != nil {
|
if cfg != nil {
|
||||||
pluginDirs = append(pluginDirs, cfg.CLIPluginsExtraDirs...)
|
pluginDirs = append(pluginDirs, cfg.CLIPluginsExtraDirs...)
|
||||||
}
|
}
|
||||||
pluginDir, err := config.Path("cli-plugins")
|
pluginDir := filepath.Join(config.Dir(), "cli-plugins")
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
pluginDirs = append(pluginDirs, pluginDir)
|
pluginDirs = append(pluginDirs, pluginDir)
|
||||||
pluginDirs = append(pluginDirs, defaultSystemPluginDirs...)
|
pluginDirs = append(pluginDirs, defaultSystemPluginDirs...)
|
||||||
return pluginDirs, nil
|
return pluginDirs
|
||||||
}
|
}
|
||||||
|
|
||||||
func addPluginCandidatesFromDir(res map[string][]string, d string) {
|
func addPluginCandidatesFromDir(res map[string][]string, d string) {
|
||||||
@ -116,10 +112,7 @@ func listPluginCandidates(dirs []string) map[string][]string {
|
|||||||
|
|
||||||
// GetPlugin returns a plugin on the system by its name
|
// GetPlugin returns a plugin on the system by its name
|
||||||
func GetPlugin(name string, dockerCLI config.Provider, rootcmd *cobra.Command) (*Plugin, error) {
|
func GetPlugin(name string, dockerCLI config.Provider, rootcmd *cobra.Command) (*Plugin, error) {
|
||||||
pluginDirs, err := getPluginDirs(dockerCLI.ConfigFile())
|
pluginDirs := getPluginDirs(dockerCLI.ConfigFile())
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return getPlugin(name, pluginDirs, rootcmd)
|
return getPlugin(name, pluginDirs, rootcmd)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -145,11 +138,7 @@ func getPlugin(name string, pluginDirs []string, rootcmd *cobra.Command) (*Plugi
|
|||||||
|
|
||||||
// ListPlugins produces a list of the plugins available on the system
|
// ListPlugins produces a list of the plugins available on the system
|
||||||
func ListPlugins(dockerCli config.Provider, rootcmd *cobra.Command) ([]Plugin, error) {
|
func ListPlugins(dockerCli config.Provider, rootcmd *cobra.Command) ([]Plugin, error) {
|
||||||
pluginDirs, err := getPluginDirs(dockerCli.ConfigFile())
|
pluginDirs := getPluginDirs(dockerCli.ConfigFile())
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
candidates := listPluginCandidates(pluginDirs)
|
candidates := listPluginCandidates(pluginDirs)
|
||||||
if len(candidates) == 0 {
|
if len(candidates) == 0 {
|
||||||
return nil, nil
|
return nil, nil
|
||||||
@ -210,10 +199,7 @@ func PluginRunCommand(dockerCli config.Provider, name string, rootcmd *cobra.Com
|
|||||||
return nil, errPluginNotFound(name)
|
return nil, errPluginNotFound(name)
|
||||||
}
|
}
|
||||||
exename := addExeSuffix(metadata.NamePrefix + name)
|
exename := addExeSuffix(metadata.NamePrefix + name)
|
||||||
pluginDirs, err := getPluginDirs(dockerCli.ConfigFile())
|
pluginDirs := getPluginDirs(dockerCli.ConfigFile())
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, d := range pluginDirs {
|
for _, d := range pluginDirs {
|
||||||
path := filepath.Join(d, exename)
|
path := filepath.Join(d, exename)
|
||||||
|
@ -173,14 +173,11 @@ func TestErrPluginNotFound(t *testing.T) {
|
|||||||
func TestGetPluginDirs(t *testing.T) {
|
func TestGetPluginDirs(t *testing.T) {
|
||||||
cli := test.NewFakeCli(nil)
|
cli := test.NewFakeCli(nil)
|
||||||
|
|
||||||
pluginDir, err := config.Path("cli-plugins")
|
pluginDir := filepath.Join(config.Dir(), "cli-plugins")
|
||||||
assert.NilError(t, err)
|
|
||||||
expected := append([]string{pluginDir}, defaultSystemPluginDirs...)
|
expected := append([]string{pluginDir}, defaultSystemPluginDirs...)
|
||||||
|
|
||||||
var pluginDirs []string
|
pluginDirs := getPluginDirs(cli.ConfigFile())
|
||||||
pluginDirs, err = getPluginDirs(cli.ConfigFile())
|
|
||||||
assert.Equal(t, strings.Join(expected, ":"), strings.Join(pluginDirs, ":"))
|
assert.Equal(t, strings.Join(expected, ":"), strings.Join(pluginDirs, ":"))
|
||||||
assert.NilError(t, err)
|
|
||||||
|
|
||||||
extras := []string{
|
extras := []string{
|
||||||
"foo", "bar", "baz",
|
"foo", "bar", "baz",
|
||||||
@ -189,7 +186,6 @@ func TestGetPluginDirs(t *testing.T) {
|
|||||||
cli.SetConfigFile(&configfile.ConfigFile{
|
cli.SetConfigFile(&configfile.ConfigFile{
|
||||||
CLIPluginsExtraDirs: extras,
|
CLIPluginsExtraDirs: extras,
|
||||||
})
|
})
|
||||||
pluginDirs, err = getPluginDirs(cli.ConfigFile())
|
pluginDirs = getPluginDirs(cli.ConfigFile())
|
||||||
assert.DeepEqual(t, expected, pluginDirs)
|
assert.DeepEqual(t, expected, pluginDirs)
|
||||||
assert.NilError(t, err)
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user