[gocomplete] fix test name completion
This commit is contained in:
parent
6dd6a04d24
commit
c06142941d
|
@ -60,7 +60,7 @@ func main() {
|
||||||
"-covermode": complete.PredictSet("set", "count", "atomic"),
|
"-covermode": complete.PredictSet("set", "count", "atomic"),
|
||||||
"-coverpkg": complete.PredictDirs,
|
"-coverpkg": complete.PredictDirs,
|
||||||
"-cpu": complete.PredictAnything,
|
"-cpu": complete.PredictAnything,
|
||||||
"-run": predictTest("test"),
|
"-run": predictTest("Test", "Example"),
|
||||||
"-short": complete.PredictNothing,
|
"-short": complete.PredictNothing,
|
||||||
"-timeout": complete.PredictAnything,
|
"-timeout": complete.PredictAnything,
|
||||||
|
|
||||||
|
|
|
@ -12,9 +12,14 @@ import (
|
||||||
"github.com/posener/complete/match"
|
"github.com/posener/complete/match"
|
||||||
)
|
)
|
||||||
|
|
||||||
func predictTest(testType string) complete.Predicate {
|
// predictTest predict test names.
|
||||||
|
// it searches in the current directory for all the go test files
|
||||||
|
// and then all the relevant function names.
|
||||||
|
// for test names use prefix of 'Test' or 'Example', and for benchmark
|
||||||
|
// test names use 'Benchmark'
|
||||||
|
func predictTest(funcPrefix ...string) complete.Predicate {
|
||||||
return func(last string) []match.Matcher {
|
return func(last string) []match.Matcher {
|
||||||
tests := testNames(testType)
|
tests := testNames(funcPrefix)
|
||||||
options := make([]match.Matcher, len(tests))
|
options := make([]match.Matcher, len(tests))
|
||||||
for i := range tests {
|
for i := range tests {
|
||||||
options[i] = match.Prefix(tests[i])
|
options[i] = match.Prefix(tests[i])
|
||||||
|
@ -24,20 +29,20 @@ func predictTest(testType string) complete.Predicate {
|
||||||
}
|
}
|
||||||
|
|
||||||
// get all test names in current directory
|
// get all test names in current directory
|
||||||
func testNames(testType string) (tests []string) {
|
func testNames(funcPrefix []string) (tests []string) {
|
||||||
filepath.Walk("./", func(path string, info os.FileInfo, err error) error {
|
filepath.Walk("./", func(path string, info os.FileInfo, err error) error {
|
||||||
// if not a test file, skip
|
// if not a test file, skip
|
||||||
if !strings.HasSuffix(path, "_test.go") {
|
if !strings.HasSuffix(path, "_test.go") {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
// inspect test file and append all the test names
|
// inspect test file and append all the test names
|
||||||
tests = append(tests, testsInFile(testType, path)...)
|
tests = append(tests, testsInFile(funcPrefix, path)...)
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func testsInFile(testType, path string) (tests []string) {
|
func testsInFile(funcPrefix []string, path string) (tests []string) {
|
||||||
fset := token.NewFileSet()
|
fset := token.NewFileSet()
|
||||||
f, err := parser.ParseFile(fset, path, nil, 0)
|
f, err := parser.ParseFile(fset, path, nil, 0)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -47,8 +52,11 @@ func testsInFile(testType, path string) (tests []string) {
|
||||||
for _, d := range f.Decls {
|
for _, d := range f.Decls {
|
||||||
if f, ok := d.(*ast.FuncDecl); ok {
|
if f, ok := d.(*ast.FuncDecl); ok {
|
||||||
name := f.Name.String()
|
name := f.Name.String()
|
||||||
if strings.HasPrefix(name, testType) {
|
for _, prefix := range funcPrefix {
|
||||||
|
if strings.HasPrefix(name, prefix) {
|
||||||
tests = append(tests, name)
|
tests = append(tests, name)
|
||||||
|
break
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue