-
Notifications
You must be signed in to change notification settings - Fork 1.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Integrate CLI plugins into
docker help
output.
This requires a function to list all available plugins so that is added here. Signed-off-by: Ian Campbell <ijc@docker.com>
- Loading branch information
Ian Campbell
committed
Dec 13, 2018
1 parent
7163d1c
commit 328a7d7
Showing
3 changed files
with
199 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
package manager | ||
|
||
import ( | ||
"path/filepath" | ||
"testing" | ||
|
||
"gotest.tools/assert" | ||
"gotest.tools/fs" | ||
) | ||
|
||
func TestListPluginCandidates(t *testing.T) { | ||
// Populate a selection of directories with various shadowed and bogus/obscure plugin candidates. | ||
// For the purposes of this test no contents is required and permissions are irrelevant. | ||
dir := fs.NewDir(t, t.Name(), | ||
fs.WithDir( | ||
"plugins1", | ||
fs.WithFile("docker-plugin1", ""), // This appears in each directory | ||
fs.WithFile("not-a-plugin", ""), // Should be ignored | ||
fs.WithFile("docker-symlinked1", ""), // This and ... | ||
fs.WithSymlink("docker-symlinked2", "docker-symlinked1"), // ... this should both appear | ||
fs.WithDir("ignored1"), // A directory should be ignored | ||
), | ||
fs.WithDir( | ||
"plugins2", | ||
fs.WithFile("docker-plugin1", ""), | ||
fs.WithFile("also-not-a-plugin", ""), | ||
fs.WithFile("docker-hardlink1", ""), // This and ... | ||
fs.WithHardlink("docker-hardlink2", "docker-hardlink1"), // ... this should both appear | ||
fs.WithDir("ignored2"), | ||
), | ||
fs.WithDir( | ||
"plugins3", | ||
fs.WithFile("docker-plugin1", ""), | ||
fs.WithDir("ignored3"), | ||
fs.WithSymlink("docker-brokensymlink", "broken"), // A broken symlink is still a candidate (but would fail tests later) | ||
fs.WithFile("non-plugin-symlinked", ""), // This shouldn't appear, but ... | ||
fs.WithSymlink("docker-symlinked", "non-plugin-symlinked"), // ... this link to it should. | ||
), | ||
fs.WithFile("/plugins4", ""), | ||
) | ||
defer dir.Remove() | ||
|
||
var dirs []string | ||
for _, d := range []string{"plugins1", "nonexistent", "plugins2", "plugins3", "plugins4"} { | ||
dirs = append(dirs, filepath.Join(dir.Path(), d)) | ||
} | ||
|
||
candidates, err := listPluginCandidates(dirs) | ||
assert.NilError(t, err) | ||
exp := map[string][]string{ | ||
"plugin1": { | ||
filepath.Join(dir.Path(), "plugins1", "docker-plugin1"), | ||
filepath.Join(dir.Path(), "plugins2", "docker-plugin1"), | ||
filepath.Join(dir.Path(), "plugins3", "docker-plugin1"), | ||
}, | ||
"symlinked1": { | ||
filepath.Join(dir.Path(), "plugins1", "docker-symlinked1"), | ||
}, | ||
"symlinked2": { | ||
filepath.Join(dir.Path(), "plugins1", "docker-symlinked2"), | ||
}, | ||
"hardlink1": { | ||
filepath.Join(dir.Path(), "plugins2", "docker-hardlink1"), | ||
}, | ||
"hardlink2": { | ||
filepath.Join(dir.Path(), "plugins2", "docker-hardlink2"), | ||
}, | ||
"brokensymlink": { | ||
filepath.Join(dir.Path(), "plugins3", "docker-brokensymlink"), | ||
}, | ||
"symlinked": { | ||
filepath.Join(dir.Path(), "plugins3", "docker-symlinked"), | ||
}, | ||
} | ||
|
||
assert.DeepEqual(t, candidates, exp) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters