测试Golang接口错误需构造异常输入并验证错误返回。通过testing包测试函数错误,确保返回error非nil且符合预期;2. 使用httptest模拟HTTP请求,验证状态码与响应体错误信息;3. 借助mock技术模拟依赖错误,确认错误被正确处理与透传,保障错误类型、消息结构一致性。

在 Golang 中测试接口错误返回,关键在于模拟异常场景并验证返回的错误类型和内容是否符合预期。常用方法包括使用 testing 包编写单元测试、通过 httptest 模拟 HTTP 请求,以及利用 mock 技术隔离依赖。
1. 验证函数接口的错误返回
当接口是一个普通函数时,直接调用并检查返回的 error 是否为 nil 或特定值。
- 编写测试函数,传入非法参数或触发错误逻辑
- 断言返回的 error 不为 nil
- 可使用 errors.Is 或 errors.As 判断具体错误类型
示例:
func TestDivide_Error(t *testing.T) {_, err := divide(10, 0)
if err == nil {
t.Fatal("expected error, got nil")
}
if !strings.Contains(err.Error(), "divide by zero") {
t.Errorf("unexpected error message: %v", err)
}
}
2. 测试 HTTP 接口的错误响应
对于 HTTP 接口,使用 httptest.NewRecorder 和 httptest.NewRequest 模拟请求,检查返回状态码和响应体。
立即学习“go语言免费学习笔记(深入)”;
- 构造一个触发错误的 HTTP 请求(如缺少参数、非法数据)
- 使用 httptest 调用处理函数
- 检查 ResponseRecorder 的 StatusCode 是否为 4xx 或 5xx
- 解析响应 body 验证错误信息结构
示例:
func TestUserHandler_MissingName(t *testing.T) {req := httptest.NewRequest("POST", "/user", strings.NewReader(`{"age":20}`))
req.Header.Set("Content-Type", "application/json")
rr := httptest.NewRecorder()
handler := http.HandlerFunc(CreateUser)
handler.ServeHTTP(rr, req)
if status := rr.Code; status != http.StatusBadRequest {
t.Errorf("handler returned wrong status: got %v want %v", status, http.StatusBadRequest)
}
var resp map[string]string
json.Unmarshal(rr.Body.Bytes(), &resp)
if msg, ok := resp["error"]; !ok || msg == "" {
t.Errorf("expected error message in response")
}
}
3. 使用 Mock 验证依赖错误传递
当接口依赖数据库、外部服务等,可用 mock 模拟其返回错误,验证接口是否正确处理并透出错误。
- 使用 mockery 或 hand-written mock 构建模拟对象
- 设置 mock 方法返回预设错误
- 调用被测接口,验证最终返回的错误是否合理
例如:mock UserRepository.Save 返回 ErrDuplicateEmail,检查 API 是否返回 409 状态码。
基本上就这些。核心是构造能触发错误的输入,再逐层验证错误是否被正确处理和返回。Golang 的错误显式返回特性让这类测试变得直接可靠。不复杂但容易忽略的是对错误信息一致性和结构的校验。










