表驱动测试是将测试用例组织为数据表的Go语言测试模式,通过结构体切片存储输入与预期输出,使用t.Run执行子测试,提升代码可读性和维护性,适用于多输入场景和复杂边界条件验证。

在Go语言中,表驱动测试是一种常见且高效的测试模式,特别适合验证同一函数在不同输入下的行为。它通过将测试用例组织成数据表的形式,让代码更简洁、易维护。
什么是表驱动测试
表驱动测试指的是将多个测试用例封装在一个切片中,每个用例包含输入和预期输出。测试函数遍历这个列表,逐一执行并验证结果。相比写多个重复的测试函数,这种方式减少了样板代码,提高了可读性和扩展性。
基本结构与写法
定义一个结构体或使用匿名结构,表示单个测试用例。然后创建一个切片保存所有用例,在测试函数中循环运行。
func TestAdd(t *testing.T) {tests := []struct {
name string
a, b int
expected int
}{{
name: "positive numbers",
a: 2, b: 3,
expected: 5,
}, {
name: "negative numbers",
a: -2, b: -3,
expected: -5,
}, {
name: "mixed signs",
a: -1, b: 1,
expected: 0,
}}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if result := add(tt.a, tt.b); result != tt.expected {
t.Errorf("got %d, want %d", result, tt.expected)
}
})
}
}
t.Run用于子测试,能让每个用例独立报告,失败时能清楚看到是哪个场景出错。name字段帮助标识用例,便于调试。
立即学习“go语言免费学习笔记(深入)”;
处理复杂类型和错误断言
对于返回错误的函数,可以在测试结构中加入 err bool 字段来表示是否期望出错,或者直接比较错误信息。
本书是全面讲述PHP与MySQL的经典之作,书中不但全面介绍了两种技术的核心特性,还讲解了如何高效地结合这两种技术构建健壮的数据驱动的应用程序。本书涵盖了两种技术新版本中出现的最新特性,书中大量实际的示例和深入的分析均来自于作者在这方面多年的专业经验,可用于解决开发者在实际中所面临的各种挑战。
例如测试一个解析函数:
func TestParseURL(t *testing.T) {tests := []struct {
input string
valid bool
}{
{"https://example.com", true},
{"invalid-url", false},
}
for _, tt := range tests {
t.Run(tt.input, func(t *testing.T) {
_, err := url.Parse(tt.input)
if tt.valid && err != nil {
t.Error("expected no error, got", err)
} else if !tt.valid && err == nil {
t.Error("expected error, got none")
}
})
}
}
使用Helper函数提升可读性
当测试逻辑较复杂时,可以提取辅助函数或方法,避免测试内部过于臃肿。比如封装断言逻辑。
也可以为测试结构添加 run() 方法,使调用更清晰。
基本上就这些。表驱动测试是Go中推荐的做法,尤其适合输入组合多、边界情况复杂的场景。写起来不复杂但容易忽略命名和子测试的使用,注意加上描述性的名字,能让失败日志更有价值。










