首页 > 解决方案 > Golang HTTP Timeout 测试,没有按预期超时

问题描述

我构建了一个小测试用例,在经过一定时间后检查我的结束超时时的代码。但这并没有按预期工作

我正在访问一个工作正常的服务器端端点,但是如果它比平时慢会发生什么,我需要在我的一端编写代码来超时,这已经实现但我需要测试我是否正确实现了它。

这是我到目前为止所拥有的

func TestTimeout(t *testing.T) {
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
    time.Sleep(time.Second * 15)
}))
defer ts.Close()
client := &http.Client{
    Timeout: time.Second * 10,
}
myRequest,err := createMyRequest(Somedata,SomeMoreData)
res, err := client.Do(myRequest)
if err != nil {
    t.Fatal(err)
}
res.Body.Close()}

但是我的代码成功运行而没有给出超时错误(因为我没有等待 10 秒,我哪里出错了?

标签: httpgotimeout

解决方案


正如一些评论中已经指出的那样,您需要向测试服务器的端点(使用ts.URL)发出请求,如下所示:

myRequest, err := http.NewRequest(http.MethodPost, ts.URL, bytes.NewBuffer([]byte("test")))
if err != nil {
    t.Fatal(err)
}
res, err := client.Do(myRequest)
if err != nil {
    t.Fatal(err)
}
[...]

推荐阅读