Go语言通过testing包支持单元测试,测试文件需以_test.go结尾且测试函数以Test开头。使用表驱动测试可提升覆盖率,t.Run支持子测试便于定位错误。运行go test执行测试,-v参数显示详情,-cover生成覆盖率报告,配合cover工具可查看HTML格式覆盖情况。私有函数建议通过公有接口测试,避免暴露内部实现。

在Go语言中编写单元测试非常直接,标准库中的 testing 包提供了完整支持。只要遵循约定的文件命名和结构,就能快速为代码添加可靠的测试。
1. 测试文件和函数命名规则
Go要求测试文件以 _test.go 结尾,并与被测代码放在同一包中。测试函数必须以 Test 开头,参数类型为 *testing.T。
例如,若有一个文件 calculator.go,对应测试文件应命名为 calculator_test.go。
示例:
立即学习“go语言免费学习笔记(深入)”;
func Add(a, b int) int { return a + b}
对应的测试:
package mainimport “testing”func TestAdd(t *testing.T) { result := Add(2, 3) if result != 5 { t.Errorf(“期望 5,但得到 %d”, result) }}
2. 使用表驱动测试提高覆盖率
对于多个输入场景,推荐使用表驱动测试(table-driven tests),它能用一个测试函数覆盖多种情况,代码更清晰也更容易维护。
定义一个切片,每个元素代表一组输入和期望输出。
func TestAdd_TableDriven(t *testing.T) { tests := []struct { name string a, b int expected int }{ {“2+3=5”, 2, 3, 5}, {“0+0=0”, 0, 0, 0}, {“负数相加”, -1, -2, -3}, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { result := Add(tt.a, tt.b) if result != tt.expected { t.Errorf(“期望 %d,但得到 %d”, tt.expected, result) } }) }}
t.Run 可以创建子测试,便于定位具体失败的用例。
3. 运行测试和查看结果
在项目目录下运行命令:
go test
查看详细输出:
go test -v
要检查测试覆盖率:
go test -covergo test -coverprofile=coverage.out && go tool cover -html=coverage.out
最后一条命令会生成HTML页面,直观展示哪些代码被测试覆盖。
4. 测试私有函数和方法
Go不支持直接测试未导出(小写开头)的函数,但它们通常被导出函数间接调用。建议通过公共接口测试其行为。如果确实需要单独测试,可将其保留在同一包中并通过测试函数验证逻辑。
不推荐为了测试而暴露内部实现。
基本上就这些。Go的测试机制简洁高效,配合工具链能快速构建可靠的质量保障体系。
以上就是如何使用Golang编写单元测试的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1413078.html
微信扫一扫
支付宝扫一扫