]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/go: convert TestShadowingLogic to the script framework
authorMichael Matloob <matloob@golang.org>
Mon, 13 Jan 2020 18:14:49 +0000 (13:14 -0500)
committerMichael Matloob <matloob@golang.org>
Wed, 19 Feb 2020 23:28:35 +0000 (23:28 +0000)
Part of converting all tests to script framework to improve
test parallelism.

Updates #36320
Updates #17751

Change-Id: I6db652a4a515daf6e87645d34191dc9a441f5720
Reviewed-on: https://go-review.googlesource.com/c/go/+/214431
Reviewed-by: Bryan C. Mills <bcmills@google.com>
src/cmd/go/go_test.go
src/cmd/go/testdata/script/list_shadow.txt [new file with mode: 0644]
src/cmd/go/testdata/shadow/root1/src/foo/foo.go [deleted file]
src/cmd/go/testdata/shadow/root1/src/math/math.go [deleted file]
src/cmd/go/testdata/shadow/root2/src/foo/foo.go [deleted file]

index 9da94360f9ffb9ff6287d0c9ca77ea29aff5b170..57c0c6580c7838dd1aa884db16325009210ee670 100644 (file)
@@ -1639,51 +1639,6 @@ func TestSymlinkWarning(t *testing.T) {
        tg.grepStderr("ignoring symlink", "list should have reported symlink")
 }
 
-func TestShadowingLogic(t *testing.T) {
-       skipIfGccgo(t, "gccgo has no standard packages")
-       tg := testgo(t)
-       defer tg.cleanup()
-       pwd := tg.pwd()
-       sep := string(filepath.ListSeparator)
-       tg.setenv("GOPATH", filepath.Join(pwd, "testdata", "shadow", "root1")+sep+filepath.Join(pwd, "testdata", "shadow", "root2"))
-
-       // The math in root1 is not "math" because the standard math is.
-       tg.run("list", "-f", "({{.ImportPath}}) ({{.ConflictDir}})", "./testdata/shadow/root1/src/math")
-       pwdForwardSlash := strings.ReplaceAll(pwd, string(os.PathSeparator), "/")
-       if !strings.HasPrefix(pwdForwardSlash, "/") {
-               pwdForwardSlash = "/" + pwdForwardSlash
-       }
-       // The output will have makeImportValid applies, but we only
-       // bother to deal with characters we might reasonably see.
-       for _, r := range " :" {
-               pwdForwardSlash = strings.ReplaceAll(pwdForwardSlash, string(r), "_")
-       }
-       want := "(_" + pwdForwardSlash + "/testdata/shadow/root1/src/math) (" + filepath.Join(runtime.GOROOT(), "src", "math") + ")"
-       if strings.TrimSpace(tg.getStdout()) != want {
-               t.Error("shadowed math is not shadowed; looking for", want)
-       }
-
-       // The foo in root1 is "foo".
-       tg.run("list", "-f", "({{.ImportPath}}) ({{.ConflictDir}})", "./testdata/shadow/root1/src/foo")
-       if strings.TrimSpace(tg.getStdout()) != "(foo) ()" {
-               t.Error("unshadowed foo is shadowed")
-       }
-
-       // The foo in root2 is not "foo" because the foo in root1 got there first.
-       tg.run("list", "-f", "({{.ImportPath}}) ({{.ConflictDir}})", "./testdata/shadow/root2/src/foo")
-       want = "(_" + pwdForwardSlash + "/testdata/shadow/root2/src/foo) (" + filepath.Join(pwd, "testdata", "shadow", "root1", "src", "foo") + ")"
-       if strings.TrimSpace(tg.getStdout()) != want {
-               t.Error("shadowed foo is not shadowed; looking for", want)
-       }
-
-       // The error for go install should mention the conflicting directory.
-       tg.runFail("install", "./testdata/shadow/root2/src/foo")
-       want = "go install: no install location for " + filepath.Join(pwd, "testdata", "shadow", "root2", "src", "foo") + ": hidden by " + filepath.Join(pwd, "testdata", "shadow", "root1", "src", "foo")
-       if strings.TrimSpace(tg.getStderr()) != want {
-               t.Error("wrong shadowed install error; looking for", want)
-       }
-}
-
 func TestCgoDependsOnSyscall(t *testing.T) {
        if testing.Short() {
                t.Skip("skipping test that removes $GOROOT/pkg/*_race in short mode")
diff --git a/src/cmd/go/testdata/script/list_shadow.txt b/src/cmd/go/testdata/script/list_shadow.txt
new file mode 100644 (file)
index 0000000..7b24d93
--- /dev/null
@@ -0,0 +1,25 @@
+env GO111MODULE=off
+env GOPATH=$WORK/gopath/src/shadow/root1${:}$WORK/gopath/src/shadow/root2
+
+# The math in root1 is not "math" because the standard math is.
+go list -f '({{.ImportPath}}) ({{.ConflictDir}})' ./shadow/root1/src/math
+stdout '^\(.*(\\|/)src(\\|/)shadow(\\|/)root1(\\|/)src(\\|/)math\) \('$GOROOT'(\\|/)?src(\\|/)math\)$'
+
+# The foo in root1 is "foo".
+go list -f '({{.ImportPath}}) ({{.ConflictDir}})' ./shadow/root1/src/foo
+stdout '^\(foo\) \(\)$'
+
+# The foo in root2 is not "foo" because the foo in root1 got there first.
+go list -f '({{.ImportPath}}) ({{.ConflictDir}})' ./shadow/root2/src/foo
+stdout '^\(.*gopath(\\|/)src(\\|/)shadow(\\|/)root2(\\|/)src(\\|/)foo\) \('$WORK'(\\|/)?gopath(\\|/)src(\\|/)shadow(\\|/)root1(\\|/)src(\\|/)foo\)$'
+
+# The error for go install should mention the conflicting directory.
+! go install -n ./shadow/root2/src/foo
+stderr 'go install: no install location for '$WORK'(\\|/)?gopath(\\|/)src(\\|/)shadow(\\|/)root2(\\|/)src(\\|/)foo: hidden by '$WORK'(\\|/)?gopath(\\|/)src(\\|/)shadow(\\|/)root1(\\|/)src(\\|/)foo'
+
+-- shadow/root1/src/foo/foo.go --
+package foo
+-- shadow/root1/src/math/math.go --
+package math
+-- shadow/root2/src/foo/foo.go --
+package foo
\ No newline at end of file
diff --git a/src/cmd/go/testdata/shadow/root1/src/foo/foo.go b/src/cmd/go/testdata/shadow/root1/src/foo/foo.go
deleted file mode 100644 (file)
index f52652b..0000000
+++ /dev/null
@@ -1 +0,0 @@
-package foo
diff --git a/src/cmd/go/testdata/shadow/root1/src/math/math.go b/src/cmd/go/testdata/shadow/root1/src/math/math.go
deleted file mode 100644 (file)
index c91c24e..0000000
+++ /dev/null
@@ -1 +0,0 @@
-package math
diff --git a/src/cmd/go/testdata/shadow/root2/src/foo/foo.go b/src/cmd/go/testdata/shadow/root2/src/foo/foo.go
deleted file mode 100644 (file)
index f52652b..0000000
+++ /dev/null
@@ -1 +0,0 @@
-package foo