lostisland/faraday

Distinguish TimeoutErrors for open and read timeouts

Open

#718 创建于 2017年8月9日

在 GitHub 查看
 (33 评论) (1 反应) (0 负责人)Ruby (5,861 star) (997 fork)batch import
featurehelp wanted

描述

In faraday/adapter/rack.rb, TimeoutError is raised for both open and read timeouts:

timeout  = env[:request][:timeout] || env[:request][:open_timeout]
response = if timeout
  Timer.timeout(timeout, Faraday::Error::TimeoutError) { execute_request(env, rack_env) }
else ... end

According to https://stackoverflow.com/questions/10322283/what-is-timeout-and-open-timeout-in-faraday, open_timeout is for the tcp connection and timeout is for the response read.

It would be nice to have separate exception types for these timeouts. Then we could determine whether or not to retry the request. Does adding something like Faraday::Error::OpenTimeoutError and Faraday::Error::ResponseTimeoutError and using those here make sense?

贡献者指南

Distinguish TimeoutErrors for open and read timeouts · lostisland/faraday#718 | Good First Issue