Revert "go/buildutil, cmd/guru: fix tests for symlinks in guru and gorename to account for windows."
Reason: ContainingPackage must do all I/O through build.Context.
This reverts commit c945ee3be4
.
Change-Id: I625410bc754ea2d150be097bf424de2be42acde4
Reviewed-on: https://go-review.googlesource.com/33921
Reviewed-by: Alan Donovan <adonovan@google.com>
This commit is contained in:
parent
c945ee3be4
commit
07e766bf81
|
@ -9,7 +9,6 @@ import (
|
||||||
"go/build"
|
"go/build"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
"runtime"
|
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
@ -36,34 +35,25 @@ func TestIssue17515(t *testing.T) {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// symlink between /tmp/home/go/src and /tmp/home/src
|
||||||
|
if err = os.Symlink(home+"/go/src", home+"/src"); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Defer tear down (removing files, symlinks)
|
||||||
defer os.RemoveAll(home)
|
defer os.RemoveAll(home)
|
||||||
|
|
||||||
var buildContext = build.Default
|
var buildContext = build.Default
|
||||||
|
|
||||||
// Success test cases
|
// Success test cases
|
||||||
type SuccessTest struct {
|
for _, test := range []struct {
|
||||||
gopath, filename, wantSrcdir string
|
gopath, filename, wantSrcdir string
|
||||||
}
|
}{
|
||||||
|
|
||||||
successTests := []SuccessTest{
|
|
||||||
{home + "/go", home + "/go/src/test/test.go", home + "/go/src"},
|
{home + "/go", home + "/go/src/test/test.go", home + "/go/src"},
|
||||||
}
|
{home + "/go", home + "/src/test/test.go", home + "/go/src"},
|
||||||
|
{home, home + "/src/test/test.go", home + "/src"},
|
||||||
// Add symlink cases if not on windows
|
{home, home + "/go/src/test/test.go", home + "/src"},
|
||||||
if runtime.GOOS != "windows" {
|
} {
|
||||||
// symlink between /tmp/home/go/src and /tmp/home/src
|
|
||||||
if err := os.Symlink(home+"/go/src", home+"/src"); err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
successTests = append(successTests, []SuccessTest{
|
|
||||||
{home + "/go", home + "/src/test/test.go", home + "/go/src"},
|
|
||||||
{home, home + "/go/src/test/test.go", home + "/src"},
|
|
||||||
{home, home + "/src/test/test.go", home + "/src"},
|
|
||||||
}...)
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, test := range successTests {
|
|
||||||
buildContext.GOPATH = test.gopath
|
buildContext.GOPATH = test.gopath
|
||||||
srcdir, importPath, err := guessImportPath(test.filename, &buildContext)
|
srcdir, importPath, err := guessImportPath(test.filename, &buildContext)
|
||||||
if srcdir != test.wantSrcdir || importPath != "test" || err != nil {
|
if srcdir != test.wantSrcdir || importPath != "test" || err != nil {
|
||||||
|
@ -77,23 +67,14 @@ func TestIssue17515(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Failure test cases
|
// Failure test cases
|
||||||
type FailTest struct {
|
for _, test := range []struct {
|
||||||
gopath, filename, wantErr string
|
gopath, filename, wantErr string
|
||||||
}
|
}{
|
||||||
|
|
||||||
failTests := []FailTest{
|
|
||||||
{home + "/go", home + "/go/src/fake/test.go", errFormat(home + "/go/src/fake")},
|
{home + "/go", home + "/go/src/fake/test.go", errFormat(home + "/go/src/fake")},
|
||||||
}
|
{home + "/go", home + "/src/fake/test.go", errFormat(home + "/src/fake")},
|
||||||
|
{home, home + "/src/fake/test.go", errFormat(home + "/src/fake")},
|
||||||
if runtime.GOOS != "windows" {
|
{home, home + "/go/src/fake/test.go", errFormat(home + "/go/src/fake")},
|
||||||
failTests = append(failTests, []FailTest{
|
} {
|
||||||
{home + "/go", home + "/src/fake/test.go", errFormat(home + "/src/fake")},
|
|
||||||
{home, home + "/src/fake/test.go", errFormat(home + "/src/fake")},
|
|
||||||
{home, home + "/go/src/fake/test.go", errFormat(home + "/go/src/fake")},
|
|
||||||
}...)
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, test := range failTests {
|
|
||||||
buildContext.GOPATH = test.gopath
|
buildContext.GOPATH = test.gopath
|
||||||
srcdir, importPath, err := guessImportPath(test.filename, &buildContext)
|
srcdir, importPath, err := guessImportPath(test.filename, &buildContext)
|
||||||
if !strings.HasPrefix(fmt.Sprint(err), test.wantErr) {
|
if !strings.HasPrefix(fmt.Sprint(err), test.wantErr) {
|
||||||
|
|
|
@ -68,7 +68,7 @@ func ContainingPackage(ctxt *build.Context, dir, filename string) (*build.Packag
|
||||||
|
|
||||||
resolvedFilename, err := filepath.EvalSymlinks(filepath.Dir(filename))
|
resolvedFilename, err := filepath.EvalSymlinks(filepath.Dir(filename))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, fmt.Errorf("can't evaluate symlinks of %s: %v", filepath.Dir(filename), err)
|
return nil, fmt.Errorf("can't evaluate symlinks of %s: %v", path.Dir(filename), err)
|
||||||
}
|
}
|
||||||
|
|
||||||
resolvedDir := filepath.ToSlash(resolvedFilename)
|
resolvedDir := filepath.ToSlash(resolvedFilename)
|
||||||
|
|
|
@ -24,40 +24,35 @@ func TestContainingPackage(t *testing.T) {
|
||||||
goroot := runtime.GOROOT()
|
goroot := runtime.GOROOT()
|
||||||
gopath := filepath.SplitList(os.Getenv("GOPATH"))[0]
|
gopath := filepath.SplitList(os.Getenv("GOPATH"))[0]
|
||||||
|
|
||||||
type Test struct {
|
// Make a symlink to gopath for test
|
||||||
gopath, filename, wantPkg string
|
tmp, err := ioutil.TempDir(os.TempDir(), "go")
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Unable to create a temporary directory in %s", os.TempDir())
|
||||||
}
|
}
|
||||||
|
|
||||||
tests := []Test{
|
// symlink between $GOPATH/src and /tmp/go/src
|
||||||
|
// in order to test all possible symlink cases
|
||||||
|
if err := os.Symlink(gopath+"/src", tmp+"/src"); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
defer os.RemoveAll(tmp)
|
||||||
|
|
||||||
|
for _, test := range []struct {
|
||||||
|
gopath, filename, wantPkg string
|
||||||
|
}{
|
||||||
{gopath, goroot + "/src/fmt/print.go", "fmt"},
|
{gopath, goroot + "/src/fmt/print.go", "fmt"},
|
||||||
{gopath, goroot + "/src/encoding/json/foo.go", "encoding/json"},
|
{gopath, goroot + "/src/encoding/json/foo.go", "encoding/json"},
|
||||||
{gopath, goroot + "/src/encoding/missing/foo.go", "(not found)"},
|
{gopath, goroot + "/src/encoding/missing/foo.go", "(not found)"},
|
||||||
{gopath, gopath + "/src/golang.org/x/tools/go/buildutil/util_test.go",
|
{gopath, gopath + "/src/golang.org/x/tools/go/buildutil/util_test.go",
|
||||||
"golang.org/x/tools/go/buildutil"},
|
"golang.org/x/tools/go/buildutil"},
|
||||||
}
|
{gopath, tmp + "/src/golang.org/x/tools/go/buildutil/util_test.go",
|
||||||
|
"golang.org/x/tools/go/buildutil"},
|
||||||
if runtime.GOOS != "windows" {
|
{tmp, gopath + "/src/golang.org/x/tools/go/buildutil/util_test.go",
|
||||||
// Make a symlink to gopath for test
|
"golang.org/x/tools/go/buildutil"},
|
||||||
tmp, err := ioutil.TempDir(os.TempDir(), "go")
|
{tmp, tmp + "/src/golang.org/x/tools/go/buildutil/util_test.go",
|
||||||
if err != nil {
|
"golang.org/x/tools/go/buildutil"},
|
||||||
t.Errorf("Unable to create a temporary directory in %s", os.TempDir())
|
} {
|
||||||
}
|
|
||||||
|
|
||||||
defer os.RemoveAll(tmp)
|
|
||||||
|
|
||||||
// symlink between $GOPATH/src and /tmp/go/src
|
|
||||||
// in order to test all possible symlink cases
|
|
||||||
if err := os.Symlink(gopath+"/src", tmp+"/src"); err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
tests = append(tests, []Test{
|
|
||||||
{gopath, tmp + "/src/golang.org/x/tools/go/buildutil/util_test.go", "golang.org/x/tools/go/buildutil"},
|
|
||||||
{tmp, gopath + "/src/golang.org/x/tools/go/buildutil/util_test.go", "golang.org/x/tools/go/buildutil"},
|
|
||||||
{tmp, tmp + "/src/golang.org/x/tools/go/buildutil/util_test.go", "golang.org/x/tools/go/buildutil"},
|
|
||||||
}...)
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, test := range tests {
|
|
||||||
var got string
|
var got string
|
||||||
var buildContext = build.Default
|
var buildContext = build.Default
|
||||||
buildContext.GOPATH = test.gopath
|
buildContext.GOPATH = test.gopath
|
||||||
|
|
Loading…
Reference in New Issue