Go中测试错误需检查类型、内容及清理:用errors.As/errors.Is断言错误类型,strings.Contains验证关键错误消息,mock依赖模拟各类错误场景,并确保错误路径下资源正确清理。
在 Go 中测试错误返回,核心是检查函数是否按预期返回特定错误(包括类型、内容或自定义错误码),而不是只判断 err != nil。
很多函数返回 error 接口,但实际可能是自定义错误类型(如 os.PathError、fmt.Errorf 或实现 error 的结构体)。用类型断言或 errors.As 检查更可靠:
errors.As(err, &target) 判断是否为某具体错误类型(推荐,支持嵌套错误)errors.Is(err, targetErr) 判断是否等于某个已知错误值(如 io.EOF)reflect.TypeOf(err) == reflect.TypeOf(&MyError{}),它不处理包装错误仅检查错误类型不够,有时需确认错误提示内容(比如用户可见的提示、日志上下文)。可用 strings.Contains(err.Error(), "xxx") 或正则匹配,但注意:
"permission denied")fmt.Errorf("failed to open %s: %w", path, err) 包装,用 errors.Unwrap 或 errors.Is 更稳妥.Code() 或 .Reason())供测试断言,而非解析 Error() 字符串真实错误往往来自底层依赖(如文件系统、网络、数据库)。测试时应主动注入各类错误,验证函数能否正确传播、转换或处理:
Reader 接口代替直接用 os.File),在测试中传入返回预设错误的 mock 实现err 和 validationErr),明确每个错误的触发条件和优先级有状态操作(如创建临时文件、获取锁、开启事务)在出错时必须确保资源释放或回滚。测试时需验证:
defer + 计数器、或 patch 全局函数(如用 os.Remove 替换为记录调用的 stub)来观测清理行为testify/assert 或原生 testing.T.Cleanup 辅助验证终态(例如:测试结束后检查目标目录是否为空)