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

golang网络通信超时设置

解决“proxy.golang.org timeout“问题

在golang的http请求中附加用户名和密码

golang 在下载依赖包的时候出现错误:dial tcp 142.251.42.241:443: i/o timeout

golang 在下载依赖包的时候出现错误:dial tcp 142.251.42.241:443: i/o timeout