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

在Go语言中编写单元测试非常直接,标准库中的 testing 包提供了完整支持。只要遵循约定的文件命名和结构,就能快速为代码添加可靠的测试。
Go要求测试文件以 _test.go 结尾,并与被测代码放在同一包中。测试函数必须以 Test 开头,参数类型为 *testing.T。
例如,若有一个文件 calculator.go,对应测试文件应命名为 calculator_test.go。
示例:
立即学习“go语言免费学习笔记(深入)”;
func Add(a, b int) int { return a + b }对应的测试:
package main import "testing" func TestAdd(t *testing.T) { result := Add(2, 3) if result != 5 { t.Errorf("期望 5,但得到 %d", result) } }对于多个输入场景,推荐使用表驱动测试(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 可以创建子测试,便于定位具体失败的用例。
在项目目录下运行命令:
go test查看详细输出:
go test -v要检查测试覆盖率:
go test -cover go test -coverprofile=coverage.out && go tool cover -html=coverage.out最后一条命令会生成HTML页面,直观展示哪些代码被测试覆盖。
Go不支持直接测试未导出(小写开头)的函数,但它们通常被导出函数间接调用。建议通过公共接口测试其行为。如果确实需要单独测试,可将其保留在同一包中并通过测试函数验证逻辑。
不推荐为了测试而暴露内部实现。
基本上就这些。Go的测试机制简洁高效,配合工具链能快速构建可靠的质量保障体系。
以上就是如何使用Golang编写单元测试的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号