Go中通过表驱动测试实现参数化,使用切片定义输入和期望输出,结合t.Run命名子测试,便于定位问题并提升可维护性。

在Golang中实现测试用例参数化,可以通过使用 表驱动测试(Table-Driven Tests) 的方式来完成。这是Go语言中最常见、最推荐的做法,能够用一组输入和期望输出来批量验证函数行为,提升测试覆盖率和可维护性。
表驱动测试是指将测试用例组织成一个切片,每个元素包含输入数据和预期结果。通过循环遍历这些用例,逐一执行并验证结果。这种方式避免了重复编写多个相似的测试函数。
示例:测试一个加法函数假设我们有一个简单的加法函数:
func Add(a, b int) int {
return a + b
}
我们可以这样写参数化的测试:
立即学习“go语言免费学习笔记(深入)”;
func TestAdd(t *testing.T) {
tests := []struct {
name string
a, b int
expected int
}{
{"positive numbers", 2, 3, 5},
{"negative numbers", -1, -1, -2},
{"zero", 0, 0, 0},
{"mixed", -5, 5, 0},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
result := Add(tt.a, tt.b)
if result != tt.expected {
t.Errorf("Add(%d, %d) = %d; expected %d", tt.a, tt.b, result, tt.expected)
}
})
}
}
t.Run 可以为每个测试用例命名,运行时能清楚看到是哪个用例失败。配合 -run 标志还可以单独运行某个用例:
go test -run=TestAdd/positive —— 只运行正数相加的用例表驱动不仅适用于简单函数,还可用于:
func Divide(a, b float64) (float64, error) {
if b == 0 {
return 0, errors.New("division by zero")
}
return a / b, nil
}
func TestDivide(t *testing.T) {
tests := []struct {
name string
a, b float64
expected float64
expectErr bool
}{
{"valid division", 6, 3, 2, false},
{"divide by zero", 1, 0, 0, true},
{"negative", -4, 2, -2, false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
result, err := Divide(tt.a, tt.b)
if tt.expectErr {
if err == nil {
t.Error("expected error but got none")
}
} else {
if err != nil {
t.Errorf("unexpected error: %v", err)
}
if result != tt.expected {
t.Errorf("got %f, want %f", result, tt.expected)
}
}
})
}
}
setup() 或 teardown() 函数以上就是如何在Golang中实现测试用例参数化的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号