【发布时间】:2023-03-26 04:55:01
【问题描述】:
我有一个通过 http 获得响应的函数。它运行一些测试。最近开始发生测试永远不会完成的情况。所以我介绍了一个超时。然后我发现如果我停止数据库服务器,测试脚本会以一个 db 错误结束,这实际上很好地导致了测试没有按预期完成的原因。所以得到错误可以帮助我节省时间。因为我不必再次手动重现整个测试。
Q1:有没有办法让连接超时,但在数据库服务器重启后得到响应?请注意,我不能再次发送 http 请求,因为它会启动相同的文本再次。
Q2:我认为解决方案是在“等待”http 响应时引入计时器。但我不知道该怎么做。有什么想法吗?
我的功能是这样的
def execute_db2_script(url)
db2_database = 'RATIONAL'
http_read_timeout=$http_read_timeout
uri = URI.parse(url)
start = Time.new
connection = Net::HTTP.new(uri.host, 443)
connection.use_ssl = true
begin
response = connection.start() do |http|
http.open_timeout = 50
http.read_timeout = http_read_timeout
http.request_get(uri.request_uri)
end
rescue Timeout::Error
time_out_message ="security time out - after #{$http_read_timeout} sec"
return time_out_message
end
return response.body.gsub("\n","<BR>")
end
【问题讨论】:
-
如果您pass a block to
request_get(),在超时之前您是否收到任何响应? -
如果我在浏览器中使用相同的 url,我将一无所获,直到我重新启动数据库服务器。该测试包含所有其他测试,因此我需要强制完成它。超时没问题,但我想要错误消息。
-
哇,听起来坏了。我不会尝试修复测试,听起来需要修复处理请求的数据库服务器或 Web 服务器......
-
是的,它坏了,测试发现它是这样的。 ;-) 它并不总是发生。它现在开始发生了,程序员还没有修复它,所以我必须在我的测试中适应它。