Golang HTTP Timeout 测试,没有按预期超时
Posted
技术标签:
【中文标题】Golang HTTP Timeout 测试,没有按预期超时【英文标题】:Golang HTTP Timeout test, not timing out as expected 【发布时间】: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
发出请求。
【参考方案1】:
正如在某些 cmets 中已经指出的,您需要向测试服务器的端点发出请求(使用 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)
[...]
【讨论】:
以上是关于Golang HTTP Timeout 测试,没有按预期超时的主要内容,如果未能解决你的问题,请参考以下文章
golang golang_chan_select_timeout.go
解决“proxy.golang.org timeout“问题
golang 在下载依赖包的时候出现错误:dial tcp 142.251.42.241:443: i/o timeout
golang 在下载依赖包的时候出现错误:dial tcp 142.251.42.241:443: i/o timeout