From 0800f9a0a23697185ced11f532eea4904043d4f0 Mon Sep 17 00:00:00 2001 From: Cody Oss <6331106+codyoss@users.noreply.github.com> Date: Sun, 12 Jan 2020 12:07:31 -0700 Subject: [PATCH] refactor method names for reflect/source (#376) The reflect method should be renamed so it does not collide with the reflect package name. As is, it makes import reflect in the code non-idiomatic. Also renamed sourceMode to stay consistent. Noticed this here: #371 Also, refactor slice equals method --- mockgen/mockgen.go | 4 ++-- mockgen/mockgen_test.go | 23 ++--------------------- mockgen/parse.go | 3 ++- mockgen/parse_test.go | 2 +- mockgen/reflect.go | 3 ++- 5 files changed, 9 insertions(+), 26 deletions(-) diff --git a/mockgen/mockgen.go b/mockgen/mockgen.go index f3835b10..d5090c0b 100644 --- a/mockgen/mockgen.go +++ b/mockgen/mockgen.go @@ -62,13 +62,13 @@ func main() { var pkg *model.Package var err error if *source != "" { - pkg, err = parseFile(*source) + pkg, err = sourceMode(*source) } else { if flag.NArg() != 2 { usage() log.Fatal("Expected exactly two arguments") } - pkg, err = reflect(flag.Arg(0), strings.Split(flag.Arg(1), ",")) + pkg, err = reflectMode(flag.Arg(0), strings.Split(flag.Arg(1), ",")) } if err != nil { log.Fatalf("Loading input failed: %v", err) diff --git a/mockgen/mockgen_test.go b/mockgen/mockgen_test.go index 8d926db3..1c139d70 100644 --- a/mockgen/mockgen_test.go +++ b/mockgen/mockgen_test.go @@ -2,6 +2,7 @@ package main import ( "fmt" + "reflect" "regexp" "strings" "testing" @@ -327,29 +328,9 @@ func TestGetArgNames(t *testing.T) { g := generator{} result := g.getArgNames(testCase.method) - if !testEqSliceStr(t, result, testCase.expected) { + if !reflect.DeepEqual(result, testCase.expected) { t.Fatalf("expected %s, got %s", result, testCase.expected) } }) } } - -func testEqSliceStr(t *testing.T, a, b []string) bool { - t.Helper() - - if a == nil || b == nil { - return false - } - - if len(a) != len(b) { - return false - } - - for i := range a { - if a[i] != b[i] { - return false - } - } - - return true -} diff --git a/mockgen/parse.go b/mockgen/parse.go index 5519507f..e35d16f5 100644 --- a/mockgen/parse.go +++ b/mockgen/parse.go @@ -41,7 +41,8 @@ var ( // TODO: simplify error reporting -func parseFile(source string) (*model.Package, error) { +// sourceMode generates mocks via source file. +func sourceMode(source string) (*model.Package, error) { srcDir, err := filepath.Abs(filepath.Dir(source)) if err != nil { return nil, fmt.Errorf("failed getting source directory: %v", err) diff --git a/mockgen/parse_test.go b/mockgen/parse_test.go index a41fa0cf..dab22fa5 100644 --- a/mockgen/parse_test.go +++ b/mockgen/parse_test.go @@ -110,6 +110,6 @@ func checkGreeterImports(t *testing.T, imports map[string]string) { func Benchmark_parseFile(b *testing.B) { source := "internal/tests/performance/big_interface/big_interface.go" for n := 0; n < b.N; n++ { - parseFile(source) + sourceMode(source) } } diff --git a/mockgen/reflect.go b/mockgen/reflect.go index 15f819ce..47f95ef2 100644 --- a/mockgen/reflect.go +++ b/mockgen/reflect.go @@ -132,7 +132,8 @@ func runInDir(program []byte, dir string) (*model.Package, error) { return run(filepath.Join(tmpDir, progBinary)) } -func reflect(importPath string, symbols []string) (*model.Package, error) { +// reflectMode generates mocks via reflection on an interface. +func reflectMode(importPath string, symbols []string) (*model.Package, error) { // TODO: sanity check arguments if *execOnly != "" {