From 5a26dc39b3391264e1114f164612fac0b637e0fe Mon Sep 17 00:00:00 2001 From: Vladimir Vivien Date: Fri, 15 Jan 2021 14:31:18 -0500 Subject: [PATCH] Fix to properly parse key=value pair from args flag Signed-off-by: Vladimir Vivien --- cmd/buildinfo.go | 6 +++--- cmd/{crash-dianostics.go => crashd.go} | 6 +++--- cmd/run.go | 19 ++++++++++--------- 3 files changed, 16 insertions(+), 15 deletions(-) rename cmd/{crash-dianostics.go => crashd.go} (87%) diff --git a/cmd/buildinfo.go b/cmd/buildinfo.go index df7acc74..6125dd55 100644 --- a/cmd/buildinfo.go +++ b/cmd/buildinfo.go @@ -14,10 +14,10 @@ func newBuildinfoCommand() *cobra.Command { cmd := &cobra.Command{ Args: cobra.NoArgs, Use: "version", - Short: "prints the crash-diagnostics version", - Long: "prints the crash-diagnostics version and other build info", + Short: "prints version", + Long: "Prints version information for the program", RunE: func(cmd *cobra.Command, args []string) error { - fmt.Printf("Version:%s\nGitSHA: %s\n", buildinfo.Version, buildinfo.GitSHA) + fmt.Printf("Version: %s\nGitSHA: %s\n", buildinfo.Version, buildinfo.GitSHA) return nil }, } diff --git a/cmd/crash-dianostics.go b/cmd/crashd.go similarity index 87% rename from cmd/crash-dianostics.go rename to cmd/crashd.go index 2dd078f4..38dd1105 100644 --- a/cmd/crash-dianostics.go +++ b/cmd/crashd.go @@ -4,11 +4,11 @@ package cmd import ( - "fmt" "os" "github.com/sirupsen/logrus" "github.com/spf13/cobra" + "github.com/vmware-tanzu/crash-diagnostics/buildinfo" ) @@ -28,8 +28,8 @@ func crashDiagnosticsCommand() *cobra.Command { cmd := &cobra.Command{ Args: cobra.NoArgs, Use: CliName, - Short: fmt.Sprintf("%s helps to troubleshoot kubernetes cluster", CliName), - Long: fmt.Sprintf("%s collects diagnostics from an unresponsive Kubernetes cluster", CliName), + Short: "runs the crashd program", + Long: "Runs the crashd program to execute script that interacts with Kubernetes clusters", PersistentPreRunE: func(cmd *cobra.Command, args []string) error { return preRun(flags) }, diff --git a/cmd/run.go b/cmd/run.go index 3594a585..72561b36 100644 --- a/cmd/run.go +++ b/cmd/run.go @@ -5,6 +5,7 @@ package cmd import ( "os" + "strings" "github.com/pkg/errors" "github.com/spf13/cobra" @@ -31,21 +32,21 @@ func newRunCommand() *cobra.Command { cmd := &cobra.Command{ Args: cobra.ExactArgs(1), Use: "run ", - Short: "Executes a diagnostics script file", - Long: "Executes a diagnostics script and collects its output as an archive bundle", + Short: "runs a script file", + Long: "Parses and executes the specified script file", RunE: func(cmd *cobra.Command, args []string) error { return run(flags, args[0]) }, } - cmd.Flags().StringToStringVar(&flags.args, "args", flags.args, "comma-separated key=value arguments to pass to the diagnostics file") - cmd.Flags().StringVar(&flags.argsFile, "args-file", flags.argsFile, "path to the file having key=value arguments to pass to the diagnostics file") + cmd.Flags().StringToStringVar(&flags.args, "args", flags.args, "comma-separated key=value pairs passed to the script (i.e. --args 'key0=val0,key1=val1')") + cmd.Flags().StringVar(&flags.argsFile, "args-file", flags.argsFile, "path to a file containing key=value argument pairs that are passed to the script file") return cmd } func run(flags *runFlags, path string) error { file, err := os.Open(path) if err != nil { - return errors.Wrapf(err, "script file not found: %s", path) + return errors.Wrapf(err, "failed to open script file: %s", path) } defer file.Close() @@ -65,18 +66,18 @@ func run(flags *runFlags, path string) error { // It builds the map from the args-file as well as the args flag passed to // the run command. func processScriptArguments(flags *runFlags) (map[string]string, error) { - // initialize the script arguments map scriptArgs := map[string]string{} - // populates the scriptArgs map from the scriptArgs-file + // get args from script args file err := util.ReadArgsFile(flags.argsFile, scriptArgs) if err != nil && flags.argsFile != ArgsFile { return nil, errors.Wrapf(err, "failed to parse scriptArgs file: %s", flags.argsFile) } - // values specified by the args flag override the values from the args-file flag + // any value specified by the args flag overrides + // value with same key in the args-file for k, v := range flags.args { - scriptArgs[k] = v + scriptArgs[strings.TrimSpace(k)] = strings.TrimSpace(v) } return scriptArgs, nil