From 493a75e955093fbe3cf5f3104d2555b8f4c19acc Mon Sep 17 00:00:00 2001 From: Leonardo Di Donato Date: Thu, 22 Nov 2018 22:50:51 +0100 Subject: [PATCH] feat(cmd/pkg): run methods for get and run commands Signed-off-by: Leonardo Di Donato --- pkg/cmd/get.go | 17 ++++++++++++++++- pkg/cmd/run.go | 18 ++++++++++++++++-- 2 files changed, 32 insertions(+), 3 deletions(-) diff --git a/pkg/cmd/get.go b/pkg/cmd/get.go index d413bd17..3739e334 100644 --- a/pkg/cmd/get.go +++ b/pkg/cmd/get.go @@ -6,7 +6,6 @@ import ( "github.com/fntlnz/kubectl-trace/pkg/factory" "github.com/spf13/cobra" "k8s.io/cli-runtime/pkg/genericclioptions" - // "k8s.io/kubernetes/pkg/kubectl/util/templates" ) var ( @@ -74,6 +73,9 @@ func NewGetCommand(factory factory.Factory, streams genericclioptions.IOStreams) if err := o.Complete(factory, c, args); err != nil { return err } + if err := o.Run(); err != nil { + return err + } return nil }, } @@ -100,16 +102,29 @@ func (o *GetOptions) Validate(cmd *cobra.Command, args []string) error { // Complete completes the setup of the command. func (o *GetOptions) Complete(factory factory.Factory, cmd *cobra.Command, args []string) error { + var err error o.namespace, o.explicitNamespace, _ = factory.ToRawKubeConfigLoader().Namespace() + if err != nil { + return err + } + // All namespaces, when present, overrides namespace flag if cmd.Flag("all-namespaces").Changed { o.allNamespaces = *o.ResourceBuilderFlags.AllNamespaces o.explicitNamespace = false o.namespace = "" } + // Need either a namespace, a trace ID, or all namespaces if o.traceArg == "" && !o.allNamespaces && !o.explicitNamespace { return fmt.Errorf(missingTargetErr) } + // todo > init printers (need PrintFlags) + + return nil +} + +// Run executes the get command. +func (o *GetOptions) Run() error { return nil } diff --git a/pkg/cmd/run.go b/pkg/cmd/run.go index 55a1650f..fa5259e2 100644 --- a/pkg/cmd/run.go +++ b/pkg/cmd/run.go @@ -70,6 +70,9 @@ func NewRunCommand(factory factory.Factory, streams genericclioptions.IOStreams) if err := o.Complete(factory, c, args); err != nil { return err } + if err := o.Run(); err != nil { + return err + } return nil }, } @@ -122,12 +125,23 @@ func (o *RunOptions) Validate(cmd *cobra.Command, args []string) error { // Complete completes the setup of the command. func (o *RunOptions) Complete(factory factory.Factory, cmd *cobra.Command, args []string) error { - o.namespace, o.explicitNamespace, _ = factory.ToRawKubeConfigLoader().Namespace() + var err error + o.namespace, o.explicitNamespace, err = factory.ToRawKubeConfigLoader().Namespace() + if err != nil { + return err + } spew.Dump(o) + b := factory.NewBuilder() + spew.Dump(b) - // get resource by pof | type/name + // get resource by pod | type/name // get container return nil } + +// Run executes the run command. +func (o *RunOptions) Run() error { + return nil +}