Golang 中的单元测试是使用标准库 testing 来实现的,编写一个单元测试是很容易的:
https://github.com/luduoxin/json-validator-go 为例,validator包中的 scanner.go 文件中的关键函数 Valid 用于校验给定字符串是否 json 格式,对应的单元测试文件为 scanner_test.go,里面的测试函数为 TestValid。scanner_test.go 的源代码如下:
package validator
import "testing"
var validTests = []struct {
data string
ok bool
}{
{`foo`, false},
{`}{`, false},
{`{]`, false},
{`123`, false},
{`123.5`, false},
{`0.5`, false},
{`true`, false},
{`false`, false},
{`null`, false},
{`[1,2,3]`, false},
{`["a","b","c"]`, false},
{`{"foo":bar}`, false},
{`[{"foo":"bar"},]`, false},
{`{}`, true},
{`[]`, true},
{`[{}]`, true},
{`{"foo":"bar"}`, true},
{`{"foo":"bar","bar":{"baz":["qux"]}}`, true},
{`[{"a":"[\"c\":\"d\"]"}]`, true},
{`[{"a":[]}]`, true},
{` {"a":"b"}`, true},
{` {"a":"b"} `, true},
{`{"a":"b"} `, true},
{`{"a": "b"} `, true},
}
func TestValid(t *testing.T) {
for _, tt := range validTests {
if ok := Valid([]byte(tt.data)); ok != tt.ok {
t.Errorf("Valid(%#q) = %v, want %v", tt.data, ok, tt.ok)
}
}
}
这个源代码相关来说比较复杂,因为测试的数据种类比较多,如果是只想简单测试一下,代码如下:
package validator
import "testing"
func TestValid(t *testing.T) {
str := `{"a": "b"}`
if ok := Valid([]byte(str)); !ok {
t.Errorf("Valid(%#q) = %v, want %v", str, ok, true)
}
}
使用 go test 命令可以运行单元测试用例,使用方法如下:
# 执行当前目录下的全部测试用例,不递归子目录中的测试用例
go test .
# 执行当前目录下的全部测试用例,递归子目录中的测试用例
go test ./...
# 执行当前目录下的全部测试用例并显示测试过程中的日志内容,不递归子目录中的测试用例
go test -v .
# 执行当前目录下的全部测试用例并显示测试过程中的日志内容,递归子目录中的测试用例
go test -v ./...
# 执行指定的测试用例
go test -v . -test.run '^TestValid$'
启动命令行,切换到 json-validator-go 项目的 validator 文件夹下,运行全部测试用例:
$ go test -v .
=== RUN TestValid
--- PASS: TestValid (0.00s)
PASS
ok github.com/luduoxin/json-validator-go/validator
运行指定测试用例 TestValid :
$ go test -v . -test.run '^TestValid$'
=== RUN TestValid
--- PASS: TestValid (0.00s)
PASS
ok github.com/luduoxin/json-validator-go/validator