gotestsum
runs tests using go test --json
, prints friendly test output and a summary of the test run.
It is designed for both local development, and running tests in a CI system.
See the complete list of features below.
Download a binary from releases, or build from
source with go get gotest.tools/gotestsum
.
A demonstration of three --format
options.
- Format - custom output format
- Summary - summary of the test run
- JUnit XML file - for integration with CI systems
- JSON file - may be used to get insights into test runs
- Post run command - may be used for desktop notification
- Re-running failed tests - to save time when dealing with flaky test suites
- Using go test flags and custom commands
- Executing a compiled test binary
- Finding and skipping slow tests - using
gotestsum tool slowest
Integrations
Set a format with the --format
flag or the GOTESTSUM_FORMAT
environment
variable.
gotestsum --format testname
Supported formats:
dots
- print a character for each test.pkgname
(default) - print a line for each package.pkgname-and-test-fails
- print a line for each package, and failed test output.testname
- print a line for each test and package.standard-quiet
- the standardgo test
format.standard-verbose
- the standardgo test -v
format.
Have a suggestion for some other format? Please open an issue!
A summary of the test run is printed after the test output.
DONE 101 tests[, 3 skipped][, 2 failures][, 1 error] in 0.103s
The summary includes:
- A count of: tests run, tests skipped, tests failed, and package build errors.
- Elapsed time including time to build.
- Test output of all failed and skipped tests, and any package build errors.
To disable parts of the summary use --no-summary section
.
Example: hide skipped tests in the summary
gotestsum --no-summary=skipped
Example: hide failed and skipped
gotestsum --no-summary=skipped,failed
Example: hide output in the summary, only print names of failed and skipped tests and errors
gotestsum --no-summary=output
When the --junitfile
flag or GOTESTSUM_JUNITFILE
environment variable are set
to a file path, gotestsum
will write a test report, in JUnit XML format, to the file.
This file can be used to integrate with CI systems.
gotestsum --junitfile unit-tests.xml
If the package names in the testsuite.name
or testcase.classname
fields do not
work with your CI system these values can be customized using the
--junitfile-testsuite-name
, or --junitfile-testcase-classname
flags. These flags
accept the following values:
short
- the base name of the package (the single term specified by the package statement).relative
- a package path relative to the root of the repositoryfull
- the full package path (default)
Note: If Go is not installed, or the go
binary is not in PATH
, the GOVERSION
environment variable can be set to remove the "failed to lookup go version for junit xml"
warning.
When the --jsonfile
flag or GOTESTSUM_JSONFILE
environment variable are set
to a file path, gotestsum
will write a line-delimited JSON file with all the
test2json
output that was written by go test --json
. This file can be used to compare test
runs, or find flaky tests.
gotestsum --jsonfile test-output.log
The --post-run-command
flag may be used to execute another command after the
test run has completed. The binary will be run with the following environment
variables set:
GOTESTSUM_FORMAT # gotestsum format (ex: short)
GOTESTSUM_JSONFILE # path to the jsonfile, empty if no file path was given
GOTESTSUM_JUNITFILE # path to the junit.xml file, empty if no file path was given
TESTS_ERRORS # number of errors
TESTS_FAILED # number of failed tests
TESTS_SKIPPED # number of skipped tests
TESTS_TOTAL # number of tests run
To get more details about the test run, such as failure messages or the full list of failed
tests, run gotestsum
with either a --jsonfile
or --junitfile
and parse the
file from the post-run-command. The
gotestsum/testjson
package may be used to parse the JSON file output.
Example: desktop notifications
First install the example notification command with go get gotest.tools/gotestsum/contrib/notify
.
The command will be downloaded to $GOPATH/bin
as notify
. Note that this
example notify
command only works on macOS with
terminal-notifer installed.
gotestsum --post-run-command notify
When the --rerun-fails
flag is set, gotestsum
will re-run any failed tests.
The tests will be re-run until each passes once, or the number of attempts
exceeds the maximum attempts. Maximum attempts defaults to 2, and can be changed
with --rerun-fails=n
.
To avoid re-running tests when there are real failures, the re-run will be
skipped when there are too many test failures. By default this value is 10, and
can be changed with --rerun-fails-max-failures=n
.
Note that using --rerun-fails
may require the use of other flags, depending on
how you specify args to go test
:
-
when used with
--raw-command
the re-run will pass additional arguments to the command. The first arg is the name of a go package, and the second is a-run
flag with a regex that matches all the failed tests in that package. These additional args can be passed togo test
, or a test binary. -
when used with any
go test
args (anything after--
on the command line), the list of packages to test must be specified as a space separated list using the--packages
arg.Example
gotestsum --rerun-fails --packages="./..." -- -count=2
-
if any of the
go test
args should be passed to the test binary, instead ofgo test
itself, the-args
flag must be used to separate the two groups of arguments.-args
is a special flag that is understood bygo test
to indicate that any following args should be passed directly to the test binary.Example
gotestsum --rerun-fails --packages="./..." -- -count=2 -args -update-golden
By default gotestsum
runs tests using the command go test --json ./...
. You
can change the command with positional arguments after a --
. You can change just the
test directory value (which defaults to ./...
) by setting the TEST_DIRECTORY
environment variable.
You can use --debug
to echo the command before it is run.
Example: set build tags
gotestsum -- -tags=integration ./...
Example: run tests in a single package
gotestsum -- ./io/http
Example: enable coverage
gotestsum -- -coverprofile=cover.out ./...
Example: run a script instead of go test
gotestsum --raw-command -- ./scripts/run_tests.sh
Note: when using --raw-command
you must ensure that the stdout produced by
the script only contains the test2json
output. Any stderr produced by the script
will be considered an error (this behaviour is necessary because package build errors
are only reported by writting to stderr, not the test2json
stdout). Any stderr
produced by tests is not considered an error (it will be in the test2json
stdout).
Example: using TEST_DIRECTORY
TEST_DIRECTORY=./io/http gotestsum
gotestsum
supports executing a compiled test binary (created with go test -c
) by running
it as a custom command.
The -json
flag is handled by go test
itself, it is not available when using a
compiled test binary, so go tool test2json
must be used to get the output
that gotestsum
expects.
Example: running ./binary.test
gotestsum --raw-command -- go tool test2json -t -p pkgname ./binary.test -test.v
pkgname
is the name of the package being tested, it will show up in the test
output. ./binary.test
is the path to the compiled test binary. The -test.v
must be included so that go tool test2json
receives all the output.
To execute a test binary without installing Go, see running without go.
gotestsum tool slowest
reads test2json output,
from a file or stdin, and prints the names and elapsed time of slow tests.
The tests are sorted from slowest to fastest.
gotestsum tool slowest
can also rewrite the source of tests slower than the
threshold, making it possible to optionally skip them.
The test2json output can be created with gotestsum --jsonfile
or go test -json
.
See gotestsum tool slowest --help
.
Example: printing a list of tests slower than 500 milliseconds
$ gotestsum --format dots --jsonfile json.log
[.]····↷··↷·
$ gotestsum tool slowest --jsonfile json.log --threshold 500ms
gotest.tools/example TestSomething 1.34s
gotest.tools/example TestSomethingElse 810ms
Example: skipping slow tests with go test --short
Any test slower than 200 milliseconds will be modified to add:
if testing.Short() {
t.Skip("too slow for testing.Short")
}
go test -json -short ./... | gotestsum tool slowest --skip-stmt "testing.Short" --threshold 200ms
Use git diff
to see the file changes.
The next time tests are run using --short
all the slow tests will be skipped.
filewatcher will automatically set the
TEST_DIRECTORY
environment variable which makes it easy to integrate
gotestsum
.
Example: run tests for a package when any file in that package is saved
filewatcher gotestsum --format testname
Pull requests and bug reports are welcome! Please open an issue first for any big changes.
This package is heavily influenced by the pytest test runner for python
.