Add logging for invalid model errors Co-authored-by: kolaente <k@knt.li> Reviewed-on: https://kolaente.dev/vikunja/api/pulls/126
58 lines
3 KiB
Markdown
58 lines
3 KiB
Markdown
# gotests [data:image/s3,"s3://crabby-images/95a73/95a734eb40ed1b81f456bc8cbf5d611cc1bf9cff" alt="License"](https://github.com/cweill/gotests/blob/master/LICENSE) [data:image/s3,"s3://crabby-images/5cf1b/5cf1b2ab88101144ebd2cea0b3ebe4e94c251871" alt="godoc"](https://godoc.org/github.com/cweill/gotests) [data:image/s3,"s3://crabby-images/a97ac/a97aca65e599c7eed6b474f03d108471b3596039" alt="Build Status"](https://travis-ci.org/cweill/gotests) [data:image/s3,"s3://crabby-images/fc1ba/fc1ba6f77f8a867a66a27087230b21ab081a7356" alt="Coverage Status"](https://coveralls.io/github/cweill/gotests?branch=master) [data:image/s3,"s3://crabby-images/828cb/828cba3c0c0739c7d51c8421edb3701e12f62551" alt="codebeat badge"](https://codebeat.co/projects/github-com-cweill-gotests) [data:image/s3,"s3://crabby-images/ce2b1/ce2b1358fbe7aab69b707aaefe70dbb71ea0418e" alt="Go Report Card"](https://goreportcard.com/report/github.com/cweill/gotests)
|
|
|
|
`gotests` makes writing Go tests easy. It's a Golang commandline tool that generates [table driven tests](https://github.com/golang/go/wiki/TableDrivenTests) based on its target source files' function and method signatures. Any new dependencies in the test files are automatically imported.
|
|
|
|
## Demo
|
|
|
|
The following shows `gotests` in action using the [official Sublime Text 3 plugin](https://github.com/cweill/GoTests-Sublime). Plugins also exist for [Emacs](https://github.com/damienlevin/GoTests-Emacs), also [Emacs](https://github.com/s-kostyaev/go-gen-test), [Vim](https://github.com/buoto/gotests-vim), [Atom Editor](https://atom.io/packages/gotests), [Visual Studio Code](https://github.com/Microsoft/vscode-go), and [IntelliJ Goland](https://www.jetbrains.com/help/go/run-debug-configuration-for-go-test.html).
|
|
|
|
data:image/s3,"s3://crabby-images/51138/51138b81d386b3e2251d68c8bed2f7d63b6c51b7" alt="demo"
|
|
|
|
## Installation
|
|
|
|
__Minimum Go version:__ Go 1.6
|
|
|
|
Use [`go get`](https://golang.org/cmd/go/#hdr-Download_and_install_packages_and_dependencies) to install and update:
|
|
|
|
```sh
|
|
$ go get -u github.com/cweill/gotests/...
|
|
```
|
|
|
|
## Usage
|
|
|
|
From the commandline, `gotests` can generate Go tests for specific source files or an entire directory. By default, it prints its output to `stdout`.
|
|
|
|
```sh
|
|
$ gotests [options] PATH ...
|
|
```
|
|
|
|
Available options:
|
|
|
|
```
|
|
-all generate go tests for all functions and methods
|
|
|
|
-excl regexp. generate go tests for functions and methods that don't
|
|
match. Takes precedence over -only, -exported, and -all
|
|
|
|
-exported generate go tests for exported functions and methods. Takes
|
|
precedence over -only and -all
|
|
|
|
-i print test inputs in error messages
|
|
|
|
-only regexp. generate go tests for functions and methods that match only.
|
|
Takes precedence over -all
|
|
|
|
-w write output to (test) files instead of stdout
|
|
|
|
-nosubtests disable subtest generation. Only available for Go 1.7+
|
|
|
|
-template_dir optional. Path to a directory containing custom test code templates
|
|
```
|
|
|
|
## Contributions
|
|
|
|
Contributing guidelines are in [CONTRIBUTING.md](CONTRIBUTING.md).
|
|
|
|
## License
|
|
|
|
`gotests` is released under the [Apache 2.0 License](http://www.apache.org/licenses/LICENSE-2.0).
|