mirror of
https://github.com/docker/compose.git
synced 2025-07-20 12:14:41 +02:00
Merge pull request #109 from chris-crone/context-show
Add context show command
This commit is contained in:
commit
7cbbab1739
@ -46,6 +46,7 @@ func Command(opts *cliopts.GlobalOpts) *cobra.Command {
|
|||||||
createCommand(),
|
createCommand(),
|
||||||
listCommand(),
|
listCommand(),
|
||||||
removeCommand(),
|
removeCommand(),
|
||||||
|
showCommand(opts),
|
||||||
useCommand(opts),
|
useCommand(opts),
|
||||||
login.Command(),
|
login.Command(),
|
||||||
)
|
)
|
||||||
|
63
cli/cmd/context/show.go
Normal file
63
cli/cmd/context/show.go
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
/*
|
||||||
|
Copyright (c) 2020 Docker Inc.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person
|
||||||
|
obtaining a copy of this software and associated documentation
|
||||||
|
files (the "Software"), to deal in the Software without
|
||||||
|
restriction, including without limitation the rights to use, copy,
|
||||||
|
modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||||
|
of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED,
|
||||||
|
INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||||
|
HOLDERS BE LIABLE FOR ANY CLAIM,
|
||||||
|
DAMAGES OR OTHER LIABILITY,
|
||||||
|
WHETHER IN AN ACTION OF CONTRACT,
|
||||||
|
TORT OR OTHERWISE,
|
||||||
|
ARISING FROM, OUT OF OR IN CONNECTION WITH
|
||||||
|
THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package context
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
|
cliopts "github.com/docker/api/cli/options"
|
||||||
|
apicontext "github.com/docker/api/context"
|
||||||
|
"github.com/docker/api/context/store"
|
||||||
|
)
|
||||||
|
|
||||||
|
func showCommand(opts *cliopts.GlobalOpts) *cobra.Command {
|
||||||
|
return &cobra.Command{
|
||||||
|
Use: "show",
|
||||||
|
Short: "Print the current context",
|
||||||
|
Args: cobra.NoArgs,
|
||||||
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
return runShow(cmd.Context(), opts)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func runShow(ctx context.Context, opts *cliopts.GlobalOpts) error {
|
||||||
|
s := store.ContextStore(ctx)
|
||||||
|
name := apicontext.CurrentContext(ctx)
|
||||||
|
// Match behavior of existing CLI
|
||||||
|
if name != store.DefaultContextName {
|
||||||
|
if _, err := s.Get(name, nil); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fmt.Println(name)
|
||||||
|
return nil
|
||||||
|
}
|
27
cli/main.go
27
cli/main.go
@ -136,16 +136,10 @@ func main() {
|
|||||||
if opts.Config == "" {
|
if opts.Config == "" {
|
||||||
fatal(errors.New("config path cannot be empty"))
|
fatal(errors.New("config path cannot be empty"))
|
||||||
}
|
}
|
||||||
config, err := cliconfig.LoadFile(opts.Config)
|
|
||||||
|
currentContext, err := determineCurrentContext(opts.Context, opts.Config)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fatal(errors.Wrap(err, "unable to find configuration file"))
|
fatal(errors.New("unable to determine current context"))
|
||||||
}
|
|
||||||
currentContext := opts.Context
|
|
||||||
if currentContext == "" {
|
|
||||||
currentContext = config.CurrentContext
|
|
||||||
}
|
|
||||||
if currentContext == "" {
|
|
||||||
currentContext = "default"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
s, err := store.New(store.WithRoot(opts.Config))
|
s, err := store.New(store.WithRoot(opts.Config))
|
||||||
@ -200,6 +194,21 @@ func execMoby(ctx context.Context) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func determineCurrentContext(flag string, configDir string) (string, error) {
|
||||||
|
res := flag
|
||||||
|
if res == "" {
|
||||||
|
config, err := cliconfig.LoadFile(configDir)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
res = config.CurrentContext
|
||||||
|
}
|
||||||
|
if res == "" {
|
||||||
|
res = "default"
|
||||||
|
}
|
||||||
|
return res, nil
|
||||||
|
}
|
||||||
|
|
||||||
func fatal(err error) {
|
func fatal(err error) {
|
||||||
fmt.Fprint(os.Stderr, err)
|
fmt.Fprint(os.Stderr, err)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
|
71
cli/main_test.go
Normal file
71
cli/main_test.go
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
/*
|
||||||
|
Copyright (c) 2020 Docker Inc.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person
|
||||||
|
obtaining a copy of this software and associated documentation
|
||||||
|
files (the "Software"), to deal in the Software without
|
||||||
|
restriction, including without limitation the rights to use, copy,
|
||||||
|
modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||||
|
of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED,
|
||||||
|
INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||||
|
HOLDERS BE LIABLE FOR ANY CLAIM,
|
||||||
|
DAMAGES OR OTHER LIABILITY,
|
||||||
|
WHETHER IN AN ACTION OF CONTRACT,
|
||||||
|
TORT OR OTHERWISE,
|
||||||
|
ARISING FROM, OUT OF OR IN CONNECTION WITH
|
||||||
|
THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
|
||||||
|
"github.com/docker/api/cli/config"
|
||||||
|
)
|
||||||
|
|
||||||
|
var contextSetConfig = []byte(`{
|
||||||
|
"currentContext": "some-context"
|
||||||
|
}`)
|
||||||
|
|
||||||
|
func TestDetermineCurrentContext(t *testing.T) {
|
||||||
|
d, err := ioutil.TempDir("", "")
|
||||||
|
defer os.RemoveAll(d)
|
||||||
|
require.NoError(t, err)
|
||||||
|
err = ioutil.WriteFile(filepath.Join(d, config.ConfigFileName), contextSetConfig, 0644)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
// If nothing set, fallback to default
|
||||||
|
c, err := determineCurrentContext("", "")
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, "default", c)
|
||||||
|
|
||||||
|
// If context flag set, use that
|
||||||
|
c, err = determineCurrentContext("other-context", "")
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, "other-context", c)
|
||||||
|
|
||||||
|
// If no context flag, use config
|
||||||
|
c, err = determineCurrentContext("", d)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, "some-context", c)
|
||||||
|
|
||||||
|
// Ensure context flag overrides config
|
||||||
|
c, err = determineCurrentContext("other-context", d)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, "other-context", c)
|
||||||
|
}
|
@ -21,7 +21,9 @@ func main() {
|
|||||||
|
|
||||||
It("should be initialized with default context", func() {
|
It("should be initialized with default context", func() {
|
||||||
NewDockerCommand("context", "use", "default").ExecOrDie()
|
NewDockerCommand("context", "use", "default").ExecOrDie()
|
||||||
output := NewCommand("docker", "context", "ls").ExecOrDie()
|
output := NewDockerCommand("context", "show").ExecOrDie()
|
||||||
|
Expect(output).To(ContainSubstring("default"))
|
||||||
|
output = NewCommand("docker", "context", "ls").ExecOrDie()
|
||||||
Expect(output).To(Not(ContainSubstring("test-example")))
|
Expect(output).To(Not(ContainSubstring("test-example")))
|
||||||
Expect(output).To(ContainSubstring("default *"))
|
Expect(output).To(ContainSubstring("default *"))
|
||||||
})
|
})
|
||||||
@ -59,6 +61,8 @@ func main() {
|
|||||||
Expect(currentContext).To(ContainSubstring("test-example"))
|
Expect(currentContext).To(ContainSubstring("test-example"))
|
||||||
output := NewCommand("docker", "context", "ls").ExecOrDie()
|
output := NewCommand("docker", "context", "ls").ExecOrDie()
|
||||||
Expect(output).To(ContainSubstring("test-example *"))
|
Expect(output).To(ContainSubstring("test-example *"))
|
||||||
|
output = NewDockerCommand("context", "show").ExecOrDie()
|
||||||
|
Expect(output).To(ContainSubstring("test-example"))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("can run ps command", func() {
|
It("can run ps command", func() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user