Commit c931f1b6 authored by Bryan C. Mills's avatar Bryan C. Mills

misc/cgo/testshared: make -v output less verbose

Previously, 'go test -v' in this directory would result in a massive
dump of go command output, because the test plumbed -v to 'build -x'.
This change separates them into distinct flags, so that '-v' only
implies the display of default 'go' command output.

Updates #30316

Change-Id: Ifb125f35ec6a0bebe7e8286e7c546d132fb213df
Reviewed-on: https://go-review.googlesource.com/c/go/+/208232
Run-TryBot: Bryan C. Mills <bcmills@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
parent 05511a5c
...@@ -34,6 +34,8 @@ var gopathInstallDir, gorootInstallDir, suffix string ...@@ -34,6 +34,8 @@ var gopathInstallDir, gorootInstallDir, suffix string
var minpkgs = []string{"runtime", "sync/atomic"} var minpkgs = []string{"runtime", "sync/atomic"}
var soname = "libruntime,sync-atomic.so" var soname = "libruntime,sync-atomic.so"
var testX = flag.Bool("testx", false, "if true, pass -x to 'go' subcommands invoked by the test")
// run runs a command and calls t.Errorf if it fails. // run runs a command and calls t.Errorf if it fails.
func run(t *testing.T, msg string, args ...string) { func run(t *testing.T, msg string, args ...string) {
c := exec.Command(args[0], args[1:]...) c := exec.Command(args[0], args[1:]...)
...@@ -46,23 +48,19 @@ func run(t *testing.T, msg string, args ...string) { ...@@ -46,23 +48,19 @@ func run(t *testing.T, msg string, args ...string) {
// t.Fatalf if the command fails. // t.Fatalf if the command fails.
func goCmd(t *testing.T, args ...string) string { func goCmd(t *testing.T, args ...string) string {
newargs := []string{args[0], "-installsuffix=" + suffix} newargs := []string{args[0], "-installsuffix=" + suffix}
if testing.Verbose() { if *testX {
newargs = append(newargs, "-x") newargs = append(newargs, "-x")
} }
newargs = append(newargs, args[1:]...) newargs = append(newargs, args[1:]...)
c := exec.Command("go", newargs...) c := exec.Command("go", newargs...)
stderr := new(strings.Builder) stderr := new(strings.Builder)
var output []byte c.Stderr = stderr
var err error
if testing.Verbose() { if testing.Verbose() && t == nil {
fmt.Printf("+ go %s\n", strings.Join(args, " ")) fmt.Fprintf(os.Stderr, "+ go %s\n", strings.Join(args, " "))
c.Stderr = os.Stderr c.Stderr = os.Stderr
stderr.WriteString("(output above)")
} else {
c.Stderr = stderr
} }
output, err = c.Output() output, err := c.Output()
if err != nil { if err != nil {
if t != nil { if t != nil {
...@@ -72,6 +70,12 @@ func goCmd(t *testing.T, args ...string) string { ...@@ -72,6 +70,12 @@ func goCmd(t *testing.T, args ...string) string {
log.Fatalf("executing %s failed %v:\n%s", strings.Join(c.Args, " "), err, stderr) log.Fatalf("executing %s failed %v:\n%s", strings.Join(c.Args, " "), err, stderr)
} }
} }
if testing.Verbose() && t != nil {
t.Logf("go %s", strings.Join(args, " "))
if stderr.Len() > 0 {
t.Logf("%s", stderr)
}
}
return string(bytes.TrimSpace(output)) return string(bytes.TrimSpace(output))
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment