go语言的testing包用于编写单元和基准测试,无需第三方库。测试文件需以_test.go结尾,测试函数以Test开头并接收testing.T参数,如TestAdd(t testing.T)。运行go test执行测试,-v显示详情,-run=匹配特定测试,./…覆盖子目录。推荐表驱动测试,用切片定义多组用例并通过t.Run执行子测试。基准测试函数以Benchmark开头,接收testing.B,如BenchmarkAdd(b testing.B),循环执行以测量性能。

Go语言的testing包是标准库中用于编写单元测试和基准测试的核心工具。使用它不需要额外安装第三方库,只需按照约定编写测试文件并运行go test命令即可。
测试文件和函数命名规范
要让Go识别测试代码,需遵循以下规则:
- 测试文件名必须以
_test.go结尾,例如math_test.go - 测试函数必须以
Test开头,后面通常接被测函数名,如TestAdd - 测试函数参数为
t *testing.T
示例:
func TestAdd(t *testing.T) { result := Add(2, 3) if result != 5 { t.Errorf("期望 5,实际 %d", result) } }
运行测试和常用命令
在项目目录下执行命令来运行测试:
-
go test:运行当前包的所有测试 -
go test -v:显示详细输出,包括每个测试函数的执行情况 -
go test -run=Add:只运行函数名匹配Add的测试(支持正则) -
go test ./...:运行当前目录及子目录中所有包的测试
表驱动测试(table-Driven Tests)
Go推荐使用表驱动方式测试多个用例,避免重复代码。
立即学习“go语言免费学习笔记(深入)”;
func TestMultiply(t *testing.T) { tests := []struct{ name string a, b int expected int }{ {"2*3", 2, 3, 6}, {"0*5", 0, 5, 0}, {"负数", -2, 4, -8}, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { result := Multiply(tt.a, tt.b) if result != tt.expected { t.Errorf("期望 %d,实际 %d", tt.expected, result) } }) } }
t.Run 可以创建子测试,便于定位具体失败的用例。
基准测试(Benchmark)
性能测试函数以Benchmark开头,接收b *testing.B参数。
func BenchmarkAdd(b *testing.B) { for i := 0; i < b.N; i++ { Add(1, 1) } }
运行命令:go test -bench=.,会自动多次循环调用以评估性能。
清理操作与测试准备
某些测试需要初始化或资源释放,可通过如下方式处理:
- 在测试开始前设置公共逻辑(如数据库连接)
- 使用
defer进行清理
func TestWithSetup(t *testing.T) { // 模拟初始化 resource := setup() defer cleanup(resource) // 确保释放 // 执行测试逻辑 result := doSomething(resource) if result == nil { t.Fatal("结果不应为 nil") } }
基本上就这些。掌握testing包的关键是熟悉命名规范、使用表驱动写法覆盖多种场景,并通过go test命令灵活运行测试。不复杂但容易忽略细节,比如忘记-v看不到日志,或者子测试没用t.Run导致错误定位困难。


