【问题标题】:Golang HTTP Timeout test, not timing out as expectedGolang HTTP Timeout 测试,没有按预期超时
【发布时间】: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 发出请求。

标签: http go timeout


【解决方案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)
}
[...]

【讨论】:

    猜你喜欢
    • 2023-01-13
    • 2016-09-18
    • 1970-01-01
    • 2016-08-27
    • 1970-01-01
    • 2021-07-12
    • 2013-02-10
    • 2014-11-22
    • 1970-01-01
    相关资源
    最近更新 更多