Skip to content

Commit

Permalink
test: added Violation tests
Browse files Browse the repository at this point in the history
  • Loading branch information
butuzov committed May 15, 2023
1 parent 7362cb3 commit d3b4e3d
Show file tree
Hide file tree
Showing 2 changed files with 114 additions and 0 deletions.
7 changes: 7 additions & 0 deletions internal/checker/testing_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,16 @@ import (
"strings"
"testing"

"github.com/stretchr/testify/assert"
"golang.org/x/tools/txtar"
)

func ParseExprFrom(t *testing.T, fset *token.FileSet, src any) ast.Expr {
astExpr, err := parser.ParseExprFrom(fset, "a.go", src, parser.AllErrors)
assert.NoError(t, err)
return astExpr
}

func Txtar(t *testing.T, fset *token.FileSet, txtarPath string) (files []*ast.File, err error) {
t.Helper()

Expand Down
107 changes: 107 additions & 0 deletions internal/checker/violation_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,107 @@
package checker

import (
"go/ast"
"go/token"
"testing"

"github.com/stretchr/testify/assert"
)

func TestViolation(t *testing.T) {
for i := range tests {
test := tests[i]
t.Run(test.Name, func(t *testing.T) {
fset := token.NewFileSet()
expr := ParseExprFrom(t, fset, test.Expression).(*ast.CallExpr)
args := make(map[int]ast.Expr, len(test.Args))
base := []byte(test.Base)

for n := range test.Args {
args[n] = ParseExprFrom(t, fset, test.Args[n])
}

v2 := test.Violation.With(base, expr, args)
assert.Equal(t, test.ExpectedSuggest, string(v2.suggest(fset)))
assert.Equal(t, test.Message, v2.Message())
})
}
}

var tests = []struct {
Name string
Violation Violation
Expression string
Base string
Args map[int]string
ExpectedSuggest string
Message string
}{
{
Name: "alt Caller",
Violation: Violation{
Targets: Strings,
Type: Function,
Package: "regexp",
Caller: "MatchString",
Args: []int{1},
AltPackage: "foobar",
AltCaller: "Match",
},
Expression: `regexp.MatchString("[0-9]+", []bytes("foo"))`,
Args: map[int]string{1: `"foo"`},
Base: "regexp",
ExpectedSuggest: `regexp.Match("[0-9]+", "foo")`,
Message: `avoid allocations with foobar.Match`,
},
{
Name: "Has More Args Then WeNeed",
Violation: Violation{
Targets: Strings,
Type: Function,
Package: "regexp",
Caller: "MatchString",
Args: []int{1},
AltPackage: "foobar",
AltCaller: "Match",
},
Expression: `regexp.MatchString("[0-9]+", []bytes("foo"))`,
Args: map[int]string{1: `"foo"`, 2: `"foo"`, 3: `"foo"`, 4: `"foo"`},
Base: "regexp",
ExpectedSuggest: `regexp.Match("[0-9]+", "foo")`,
Message: `avoid allocations with foobar.Match`,
},
{
Name: "Regular Suggestion Work",
Violation: Violation{
Targets: Strings,
Type: Function,
Package: "regexp",
Caller: "MatchString",
Args: []int{1},
AltCaller: "Match",
},
Expression: `regexp.MatchString("[0-9]+", []bytes("foo"))`,
Args: map[int]string{1: `"foo"`},
Base: "regexp",
ExpectedSuggest: `regexp.Match("[0-9]+", "foo")`,
Message: `avoid allocations with regexp.Match`,
},
{
Name: "Methods",
Violation: Violation{
Targets: Strings,
Type: Method,
Package: "regexp",
Struct: "Regexp",
Caller: "MatchString",
Args: []int{1},
AltCaller: "Match",
},
Expression: `re.MatchString("[0-9]+", []bytes("foo"))`,
Args: map[int]string{1: `"foo"`},
Base: "re",
ExpectedSuggest: `re.Match("[0-9]+", "foo")`,
Message: `avoid allocations with (*regexp.Regexp).Match`,
},
}

0 comments on commit d3b4e3d

Please sign in to comment.