From caf8e6402ed89ebd30a364227823de0e5eac2cd5 Mon Sep 17 00:00:00 2001 From: Steven Powell Date: Wed, 20 Apr 2022 15:12:20 -0700 Subject: [PATCH 1/2] fix having flag before command cause problems --- cmd/minikube/main.go | 2 +- pkg/minikube/audit/audit.go | 23 ++++++----------------- 2 files changed, 7 insertions(+), 18 deletions(-) diff --git a/cmd/minikube/main.go b/cmd/minikube/main.go index 6f12f844b034..b7a56d375a00 100644 --- a/cmd/minikube/main.go +++ b/cmd/minikube/main.go @@ -229,7 +229,7 @@ func setFlags(parse bool) { // setLastStartFlags sets the log_file flag to lastStart.txt if start command and user doesn't specify log_file or log_dir flags. func setLastStartFlags() { - if len(os.Args) < 2 || os.Args[1] != "start" { + if pflag.Arg(0) != "start" { return } if pflag.CommandLine.Changed("log_file") || pflag.CommandLine.Changed("log_dir") { diff --git a/pkg/minikube/audit/audit.go b/pkg/minikube/audit/audit.go index 7deb87972526..eb4b0ead7199 100644 --- a/pkg/minikube/audit/audit.go +++ b/pkg/minikube/audit/audit.go @@ -22,6 +22,7 @@ import ( "strings" "time" + "github.com/spf13/pflag" "github.com/spf13/viper" "k8s.io/klog/v2" "k8s.io/minikube/pkg/minikube/config" @@ -52,10 +53,10 @@ func args() string { // Log details about the executed command. func Log(startTime time.Time) { - if len(os.Args) < 2 || !shouldLog() { + if !shouldLog() { return } - r := newRow(os.Args[1], args(), userName(), version.GetVersion(), startTime, time.Now()) + r := newRow(pflag.Arg(0), args(), userName(), version.GetVersion(), startTime, time.Now()) if err := appendToLog(r); err != nil { klog.Warning(err) } @@ -64,7 +65,7 @@ func Log(startTime time.Time) { // shouldLog returns if the command should be logged. func shouldLog() bool { // in rare chance we get here without a command, don't log - if len(os.Args) < 2 { + if pflag.NArg() == 0 { return false } @@ -74,7 +75,7 @@ func shouldLog() bool { // commands that should not be logged. no := []string{"status", "version"} - a := os.Args[1] + a := pflag.Arg(0) for _, c := range no { if a == c { return false @@ -85,17 +86,5 @@ func shouldLog() bool { // isDeletePurge return true if command is delete with purge flag. func isDeletePurge() bool { - args := os.Args - if len(args) < 2 { - return false - } - if args[1] != "delete" { - return false - } - for _, a := range args { - if a == "--purge" { - return true - } - } - return false + return pflag.Arg(0) == "delete" && viper.GetBool("purge") } From 73b9efa6950af4f04f27239bbdf8da7203940de1 Mon Sep 17 00:00:00 2001 From: Steven Powell Date: Wed, 20 Apr 2022 16:35:13 -0700 Subject: [PATCH 2/2] updated tests --- pkg/minikube/audit/audit_test.go | 45 ++++++++++++++++++++++++++------ 1 file changed, 37 insertions(+), 8 deletions(-) diff --git a/pkg/minikube/audit/audit_test.go b/pkg/minikube/audit/audit_test.go index 7c36ae655642..e91f7d972a68 100644 --- a/pkg/minikube/audit/audit_test.go +++ b/pkg/minikube/audit/audit_test.go @@ -22,6 +22,7 @@ import ( "testing" "time" + "github.com/spf13/pflag" "github.com/spf13/viper" "k8s.io/minikube/pkg/minikube/config" ) @@ -88,8 +89,11 @@ func TestAudit(t *testing.T) { }) t.Run("shouldLog", func(t *testing.T) { - oldArgs := os.Args - defer func() { os.Args = oldArgs }() + oldCommandLine := pflag.CommandLine + defer func() { + pflag.CommandLine = oldCommandLine + pflag.Parse() + }() tests := []struct { args []string @@ -122,19 +126,22 @@ func TestAudit(t *testing.T) { } for _, test := range tests { - os.Args = test.args + mockArgs(t, test.args) got := shouldLog() if got != test.want { - t.Errorf("os.Args = %q; shouldLog() = %t; want %t", os.Args, got, test.want) + t.Errorf("test.args = %q; shouldLog() = %t; want %t", test.args, got, test.want) } } }) t.Run("isDeletePurge", func(t *testing.T) { - oldArgs := os.Args - defer func() { os.Args = oldArgs }() + oldCommandLine := pflag.CommandLine + defer func() { + pflag.CommandLine = oldCommandLine + pflag.Parse() + }() tests := []struct { args []string @@ -159,12 +166,12 @@ func TestAudit(t *testing.T) { } for _, test := range tests { - os.Args = test.args + mockArgs(t, test.args) got := isDeletePurge() if got != test.want { - t.Errorf("os.Args = %q; isDeletePurge() = %t; want %t", os.Args, got, test.want) + t.Errorf("test.args = %q; isDeletePurge() = %t; want %t", test.args, got, test.want) } } }) @@ -175,6 +182,28 @@ func TestAudit(t *testing.T) { defer func() { os.Args = oldArgs }() os.Args = []string{"minikube"} + oldCommandLine := pflag.CommandLine + defer func() { + pflag.CommandLine = oldCommandLine + pflag.Parse() + }() + mockArgs(t, os.Args) + Log(time.Now()) }) } + +func mockArgs(t *testing.T, args []string) { + if len(args) == 0 { + t.Fatalf("cannot pass an empty slice to mockArgs") + } + fs := pflag.NewFlagSet(args[0], pflag.ExitOnError) + fs.Bool("purge", false, "") + if err := fs.Parse(args[1:]); err != nil { + t.Fatal(err) + } + pflag.CommandLine = fs + if err := viper.BindPFlags(pflag.CommandLine); err != nil { + t.Fatal(err) + } +}