Go 语言推荐 测试文件 和 源代码文件 放在一块 命名规范 测试文件 以 *_test.go 结尾 测试用例 以 Test* 开头 测试用例的参数,有且只有一个: t *testing.T 测试
Go 语言推荐 测试文件 和 源代码文件 放在一块
命名规范
- 测试文件 以
*_test.go
结尾 - 测试用例 以
Test*
开头 - 测试用例的参数,有且只有一个:
t *testing.T
测试示例
初始化项目
$ go version
go version go1.19 darwin/amd64
$ go mod init calc
新建两个文件
$ tree
.
├── calc.go
├── calc_test.go
└── go.mod
calc.go
package calc
func Add(a int, b int) int {
return a + b
}
func Mul(a int, b int) int {
return a * b
}
calc_test.go
package calc
import "testing"
func TestAdd(t *testing.T) {
if ret := Add(1, 2); ret != 3 {
t.Errorf("1 + 2 expected be 3, but %d got", ret)
}
}
func TestMul(t *testing.T) {
if ret := Mul(1, 2); ret != 2 {
t.Errorf("1 + 2 expected be 3, but %d got", ret)
}
}
运行测试
# 执行所有测试用例
$ go test
PASS
ok calc 0.006s
# 显示每个用例的测试结果
$ go test -v
=== RUN TestAdd
--- PASS: TestAdd (0.00s)
=== RUN TestMul
--- PASS: TestMul (0.00s)
PASS
ok calc 0.006s
# 查看覆盖率
$ go test -cover
PASS
coverage: 100.0% of statements
ok calc 0.005s
# 只运行其中一个用例
# 支持通配符 *,和部分正则表达式,例如 ^、$。
$ go test -v -run TestAdd
=== RUN TestAdd
--- PASS: TestAdd (0.00s)
PASS
ok calc 0.005s
参考
Go Test 单元测试简明教程