Skip to content

Commit

Permalink
enhanced Go test output (quiet by default, print package path)
Browse files Browse the repository at this point in the history
"ginkgo" can replace "go test" as test runner also for normal Go
tests, but the output was different:
- tests were always run with -test.v and thus produced output
  also on success
- there was no indication of which test produced the output

Now the output behavior is closer to that of "go test":
- tests run in verbose mode only when "ginkgo -v" is used
- after each test, a line with "ok/FAIL <test path>" is
  printed

That line is not quite the same as in "go test", which prints the
import path, but close enough. That line is important when running in
quite mode, because without it one would not be able to tell what
tests were run. Even in verbose mode the output could be
ambiguous (for example, when different packages happen to contain the
same test).

Example:

$ go test ./pkg/log ./pkg/log/testlog
ok  	github.com/foo/bar/pkg/log	0.005s
--- FAIL: TestOutput2 (0.00s)
	testlog_test.go:40: INFO TestOutput2
	testlog_test.go:42: was asked to fail
FAIL
FAIL	github.com/foo/bar/pkg/log/testlog	1.417s

$ ginkgo ./pkg/log ./pkg/log/testlog
PASS
ok ./pkg/log
--- FAIL: TestOutput2 (0.00s)
	testlog_test.go:40: INFO TestOutput2
	testlog_test.go:42: was asked to fail
FAIL
FAIL ./pkg/log/testlog

Ginkgo ran 2 suites in 2.145256459s
Test Suite Failed

Fixes: onsi#508
  • Loading branch information
pohly committed Sep 11, 2018
1 parent 3774a09 commit be8e104
Showing 1 changed file with 11 additions and 1 deletion.
12 changes: 11 additions & 1 deletion ginkgo/testrunner/test_runner.go
Original file line number Diff line number Diff line change
Expand Up @@ -253,7 +253,17 @@ func (t *TestRunner) runSerialGinkgoSuite() RunResult {
}

func (t *TestRunner) runGoTestSuite() RunResult {
return t.run(t.cmd([]string{"-test.v"}, os.Stdout, 1), nil)
args := make([]string, 0)
if config.DefaultReporterConfig.Verbose {
args = append(args, "-test.v")
}
result := t.run(t.cmd(args, os.Stdout, 1), nil)
keyword := "ok"
if !result.Passed {
keyword = "FAIL"
}
fmt.Printf("%s %s\n", keyword, t.Suite.Path)
return result
}

func (t *TestRunner) runAndStreamParallelGinkgoSuite() RunResult {
Expand Down

0 comments on commit be8e104

Please sign in to comment.