表格驱动测试是Go语言中通过结构化数据组织多组输入和期望输出来验证函数行为的测试模式。它将测试用例定义为切片,每个元素包含输入、预期结果及名称,利用循环和test.Run逐一执行并命名子测试,提升代码可读性和维护性。示例如TestIsEven和TestDivide展示了基本实现,支持处理正常返回与错误场景。通过添加注释、分组变量和辅助函数可优化复杂用例的可维护性,是Go推荐的清晰、扩展性强的测试方式。

在Go语言中,表格驱动测试是一种常见的测试模式,特别适合验证同一函数在多种输入情况下的行为。它通过将测试用例组织成“表格”形式,让代码更清晰、易维护。
表格驱动测试指的是把多个测试用例以结构化数据(通常是切片)的形式列出,每个用例包含输入和期望输出。测试逻辑通过遍历这些用例来执行断言。
这种方式避免了为每个场景重复写相似的测试代码,提升覆盖率和可读性。
定义一个结构体或匿名结构切片,包含输入参数和预期结果,然后在测试中循环执行。
立即学习“go语言免费学习笔记(深入)”;
示例:假设我们有一个函数 IsEven(n int) bool,判断整数是否为偶数:
func IsEven(n int) bool {
return n%2 == 0
}对应的表格测试可以这样写:
func TestIsEven(t *testing.T) {
tests := []struct {
name string
input int
expected bool
}{
{"正偶数", 4, true},
{"正奇数", 3, false},
{"负偶数", -2, true},
{"负奇数", -1, false},
{"零", 0, true},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
result := IsEven(tt.input)
if result != tt.expected {
t.Errorf("IsEven(%d) = %v; expected %v", tt.input, result, tt.expected)
}
})
}
}使用 t.Run 可以为每个子测试命名,便于定位失败用例。
当被测函数返回错误时,可以在表格中加入期望的错误信息或类型判断。
例如:
func Divide(a, b float64) (float64, error) {
if b == 0 {
return 0, fmt.Errorf("division by zero")
}
return a / b, nil
}测试用例可设计为:
func TestDivide(t *testing.T) {
tests := []struct {
name string
a, b float64
wantResult float64
wantErr bool
}{
{"正常除法", 6, 3, 2.0, false},
{"除零", 1, 0, 0, true},
{"小数结果", 5, 2, 2.5, false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
result, err := Divide(tt.a, tt.b)
if (err != nil) != tt.wantErr {
t.Fatalf("expected error: %v, got: %v", tt.wantErr, err)
}
if !tt.wantErr && result != tt.wantResult {
t.Errorf("got %f, want %f", result, tt.wantResult)
}
})
}
}实际项目中可以通过以下方式优化表格测试:
基本上就这些。表格驱动测试是Go中最推荐的测试风格之一,结构清晰,扩展方便,适合大多数函数级验证场景。不复杂但容易忽略细节,比如子测试命名和错误判断完整性。
以上就是如何在Golang中实现表格驱动测试的详细内容,更多请关注php中文网其它相关文章!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号