closes #49
Этот коммит содержится в:
родитель
ba1202b02f
коммит
a20d2de63a
2 изменённых файлов: 70 добавлений и 12 удалений
45
builder.go
45
builder.go
|
@ -9,6 +9,7 @@ import (
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
|
"path"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
"text/template"
|
"text/template"
|
||||||
|
@ -66,7 +67,7 @@ func Build() (string, error) {
|
||||||
|
|
||||||
// we allow package to be nil, if godog is run only when
|
// we allow package to be nil, if godog is run only when
|
||||||
// there is a feature file in empty directory
|
// there is a feature file in empty directory
|
||||||
pkg, _ := build.ImportDir(abs, 0)
|
pkg := importPackage(abs)
|
||||||
src, anyContexts, err := buildTestMain(pkg)
|
src, anyContexts, err := buildTestMain(pkg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return bin, err
|
return bin, err
|
||||||
|
@ -205,8 +206,8 @@ func Build() (string, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func locatePackage(try []string) (*build.Package, error) {
|
func locatePackage(try []string) (*build.Package, error) {
|
||||||
for _, path := range try {
|
for _, p := range try {
|
||||||
abs, err := filepath.Abs(path)
|
abs, err := filepath.Abs(p)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
@ -219,6 +220,29 @@ func locatePackage(try []string) (*build.Package, error) {
|
||||||
return nil, fmt.Errorf("failed to find godog package in any of:\n%s", strings.Join(try, "\n"))
|
return nil, fmt.Errorf("failed to find godog package in any of:\n%s", strings.Join(try, "\n"))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func importPackage(dir string) *build.Package {
|
||||||
|
pkg, _ := build.ImportDir(dir, 0)
|
||||||
|
|
||||||
|
// normalize import path for local import packages
|
||||||
|
// taken from go source code
|
||||||
|
// see: https://github.com/golang/go/blob/go1.7rc5/src/cmd/go/pkg.go#L279
|
||||||
|
if pkg != nil && pkg.ImportPath == "." {
|
||||||
|
pkg.ImportPath = path.Join("_", strings.Map(makeImportValid, filepath.ToSlash(dir)))
|
||||||
|
}
|
||||||
|
|
||||||
|
return pkg
|
||||||
|
}
|
||||||
|
|
||||||
|
// from go src
|
||||||
|
func makeImportValid(r rune) rune {
|
||||||
|
// Should match Go spec, compilers, and ../../go/parser/parser.go:/isValidImport.
|
||||||
|
const illegalChars = `!"#$%&'()*,:;<=>?[\]^{|}` + "`\uFFFD"
|
||||||
|
if !unicode.IsGraphic(r) || unicode.IsSpace(r) || strings.ContainsRune(illegalChars, r) {
|
||||||
|
return '_'
|
||||||
|
}
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
|
||||||
func uniqStringList(strs []string) (unique []string) {
|
func uniqStringList(strs []string) (unique []string) {
|
||||||
uniq := make(map[string]void, len(strs))
|
uniq := make(map[string]void, len(strs))
|
||||||
for _, s := range strs {
|
for _, s := range strs {
|
||||||
|
@ -266,18 +290,15 @@ func buildTestMain(pkg *build.Package) ([]byte, bool, error) {
|
||||||
// maybeVendorPaths determines possible vendor paths
|
// maybeVendorPaths determines possible vendor paths
|
||||||
// which goes levels down from given directory
|
// which goes levels down from given directory
|
||||||
// until it reaches GOPATH source dir
|
// until it reaches GOPATH source dir
|
||||||
func maybeVendorPaths(dir string) []string {
|
func maybeVendorPaths(dir string) (paths []string) {
|
||||||
paths := []string{filepath.Join(dir, "vendor", godogImportPath)}
|
|
||||||
for _, gopath := range gopaths {
|
for _, gopath := range gopaths {
|
||||||
if !strings.HasPrefix(dir, gopath) {
|
gopath = filepath.Join(gopath, "src")
|
||||||
continue
|
for strings.HasPrefix(dir, gopath) && dir != gopath {
|
||||||
}
|
paths = append(paths, filepath.Join(dir, "vendor", godogImportPath))
|
||||||
|
dir = filepath.Dir(dir)
|
||||||
for p := filepath.Dir(dir); p != filepath.Join(gopath, "src"); p = filepath.Dir(p) {
|
|
||||||
paths = append(paths, filepath.Join(p, "vendor", godogImportPath))
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return paths
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// processPackageTestFiles runs through ast of each test
|
// processPackageTestFiles runs through ast of each test
|
||||||
|
|
37
builder_test.go
Обычный файл
37
builder_test.go
Обычный файл
|
@ -0,0 +1,37 @@
|
||||||
|
package godog
|
||||||
|
|
||||||
|
import (
|
||||||
|
"go/build"
|
||||||
|
"path/filepath"
|
||||||
|
"reflect"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestVendorPaths(t *testing.T) {
|
||||||
|
gopaths = []string{"/go"}
|
||||||
|
|
||||||
|
type Case struct {
|
||||||
|
dir string
|
||||||
|
expect []string
|
||||||
|
}
|
||||||
|
|
||||||
|
cases := []Case{
|
||||||
|
{"/go", []string{}},
|
||||||
|
{"/go/src", []string{}},
|
||||||
|
{"/go/src/project", []string{"/go/src/project/vendor"}},
|
||||||
|
{"/go/src/party/project", []string{"/go/src/party/project/vendor", "/go/src/party/vendor"}},
|
||||||
|
}
|
||||||
|
|
||||||
|
for i, c := range cases {
|
||||||
|
actual := maybeVendorPaths(c.dir)
|
||||||
|
var expect []string
|
||||||
|
for _, s := range c.expect {
|
||||||
|
expect = append(expect, filepath.Join(s, godogImportPath))
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(expect, actual) {
|
||||||
|
t.Fatalf("case %d expected %+v, got %+v", i, expect, actual)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
gopaths = filepath.SplitList(build.Default.GOPATH)
|
||||||
|
}
|
Загрузка…
Создание таблицы
Сослаться в новой задаче