【发布时间】:2021-12-10 14:29:31
【问题描述】:
我构建了一个小测试用例,在经过一定时间后检查我的结束超时时的代码。但这并没有按预期工作
我正在访问一个工作正常的服务器端端点,但如果它比平时慢会发生什么,我需要在我的一端编写代码来超时,这已经实现但我需要测试我是否正确实现了它。
这是我目前所拥有的
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 秒,我哪里出错了?
【问题讨论】:
-
您没有阅读正文。使用 io.ReadAll 读取正文,您应该在等待读取完成时收到超时。
-
我不明白,我该怎么做?
-
在
client.Do之后,拨打_,err:=ioutil.ReadAll(res.Body) -
@CeriseLimón 我需要发送 Post 请求而不是 GET 请求,因此我使用 do()
-
如果您想使用函数中创建的测试服务器强制超时,那么您必须向测试服务器的 URL
ts.URL发出请求。