t.Error记录错误并继续执行,适合收集多个错误;t.Fatal记录错误后立即停止,用于关键错误。两者选择取决于是否需中断测试。
在Golang的测试中,t.Error 和 t.Fatal 都用于标记测试失败,但它们的行为有关键区别。正确使用它们能帮助你更有效地调试和控制测试流程。
t.Error:记录错误并继续执行
当你调用 t.Error 或 t.Errorf 时,测试会记录错误信息,但不会立即停止。后续代码仍会执行。
这适合你想收集多个错误或观察后续逻辑是否也出问题的情况。
• 使用场景:验证多个字段、组合条件判断• 常见写法:
func TestUserValidation(t *testing.T) {
user := User{Name: "", Age: -5}
if user.Name == "" {
t.Error("Name should not be empty")
}
if user.Age < 0 {
t.Error("Age should be positive")
}
}
这个测试会同时报告 Name 和 Age 的问题。
t.Fatal:立即终止测试
t.Fatal 或 t.Fatalf 在输出错误后会立刻停止当前测试函数。它通过 panic 实现中断,确保后面的代码不再运行。
适用于前置条件不满足、依赖初始化失败等不能继续的情况。
• 使用场景:setup 失败、必要资源缺失• 示例:
func TestDatabaseQuery(t *testing.T) { db, err := connectTestDB() if err != nil { t.Fatalf("Failed to connect to test DB: %v", err) } // 后续查询操作... }
如果数据库连不上,就没必要执行后面的查询。
选择建议
想看所有错误?用 t.Error。比如表单校验、结构体字段检查。
遇到致命问题要马上停?用 t.Fatal。比如环境配置错误、依赖服务不可用。
注意:两者都只影响当前测试函数,不会中断其他测试。
基本上就这些,根据你要表达的意图选合适的方法就行。

ting.T) {
db, err := connectTestDB()
if err != nil {
t.Fatalf("Failed to connect to test DB: %v", err)
}
// 后续查询操作...
}






