Go语言通过go test命令支持内置测试,测试文件以_test.go结尾,测试函数以Test开头并接收*testing.T参数,可进行单元测试和性能测试。

Go语言内置了轻量且高效的测试支持,通过go test命令可以方便地运行测试用例。不需要额外框架,只要遵循约定的命名规则和结构,就能快速完成单元测试、性能测试等任务。
测试文件与函数的基本规范
Go中的测试文件必须以_test.go结尾,并放在对应包目录下。测试函数名需以Test开头,参数类型为*testing.T。
例如,对mathutil.go中的加法函数进行测试:
// mathutil.go
func Add(a, b int) int {
return a + b
}
// mathutil_test.go
package main
import "testing"
func TestAdd(t *testing.T) {
result := Add(2, 3)
if result != 5 {
t.Errorf("期望 5,实际 %d", result)
}
}
执行go test命令即可运行测试:
立即学习“go语言免费学习笔记(深入)”;
go test常用go test命令选项
在实际开发中,常配合不同参数提升调试效率。
- -v:显示详细输出,包括每个测试函数的执行情况
-
-run:按正则匹配运行特定测试函数,如
go test -run TestAdd -
-count:设置执行次数,用于检测随机性问题,如
go test -count 3 - -failfast:一旦有测试失败就停止执行
组合使用示例:
go test -v -run TestAdd性能测试(基准测试)
除了功能测试,Go还支持基准测试来评估代码性能。函数名以Benchmark开头,参数为*testing.B。
func BenchmarkAdd(b *testing.B) {
for i := 0; i < b.N; i++ {
Add(2, 3)
}
}
运行基准测试:
go test -bench=.若只想运行性能测试,可加上-run=^$避免执行普通测试:
覆盖率与代码质量检查
使用-cover参数查看测试覆盖率:
生成详细的覆盖率报告文件并用浏览器查看:
go test -coverprofile=coverage.out go tool cover -html=coverage.out
这会打开一个页面,直观展示哪些代码被测试覆盖,哪些未被执行。
基本上就这些。Go的测试机制简洁实用,关键是写好断言逻辑和边界用例。配合CI流程定期运行,能有效保障代码质量。










