gotests
makes writing Go tests easy. It's a Golang commandline tool that generates table driven tests based on its target source files' function and method signatures. Any new dependencies in the test files are automatically imported.
The following shows gotests
in action using the official Sublime Text 3 plugin. Plugins also exist for Emacs, also Emacs, Vim, Atom Editor, Visual Studio Code, and IntelliJ Goland.
Minimum Go version: Go 1.6
Use go get
to install and update:
$ go get -u github.com/cweill/gotests/...
From the commandline, gotests
can generate Go tests for specific source files or an entire directory. By default, it prints its output to stdout
.
$ gotests [options] PATH ...
Available options:
-all generate tests for all functions and methods
-excl regexp. generate tests for functions and methods that don't
match. Takes precedence over -only, -exported, and -all
-exported generate tests for exported functions and methods. Takes
precedence over -only and -all
-i print test inputs in error messages
-only regexp. generate tests for functions and methods that match only.
Takes precedence over -all
-nosubtests disable subtest generation when >= Go 1.7
-parallel enable parallel subtest generation when >= Go 1.7.
-w write output to (test) files instead of stdout
-template_dir Path to a directory containing custom test code templates. Takes
precedence over -template. This can also be set via environment
variable GOTESTS_TEMPLATE_DIR
-template Specify custom test code templates, e.g. testify. This can also
be set via environment variable GOTESTS_TEMPLATE
-template_params_file read external parameters to template by json with file
-template_params read external parameters to template by json with stdin
go install github.com/mjibson/esc@latest
The entry to the test generation is render.go
func (r *Render) TestFunction() error {
return r.tmpls.ExecuteTemplate(w, "function", models.TData{
Function: f,
PrintInputs: printInputs,
Subtests: subtests,
Parallel: parallel,
Named: named,
TemplateParams: params,
})
}
Which will render the Golang template function.tmpl.
This is the starting template that will have reference to other templates.
Comment out the following in options.go and check the output
//format file
out, err := imports.Process(tf.Name(), b.Bytes(), nil)
if err != nil {
return nil, fmt.Errorf("imports.Process: %v", err)
}
To make changes to a template for example templates/testify/function.tmpl
- Change the template
- Generate the tmpl.go by running
go generate ./templates/gen.go
- Install
go install ./...
- Run
gotests gotests -all -template testify yourfile.go
Contributing guidelines are in CONTRIBUTING.md.
gotests
is released under the Apache 2.0 License.