mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/net/http.rb (Net::HTTP#connect): use connect_nonblock and
io/wait. fix GH-899 git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@50907 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
23f371fd19
commit
bab5bf0c79
2 changed files with 20 additions and 1 deletions
|
@ -1,3 +1,8 @@
|
|||
Mon Jun 15 02:26:34 2015 NARUSE, Yui <naruse@ruby-lang.org>
|
||||
|
||||
* lib/net/http.rb (Net::HTTP#connect): use connect_nonblock and
|
||||
io/wait to eliminate timeout use. fix GH-899
|
||||
|
||||
Sat Jun 13 07:21:18 2015 KOSAKI Motohiro <kosaki.motohiro@gmail.com>
|
||||
|
||||
* thread.c (thread_start_func_2): don't interrupt when last thread
|
||||
|
|
|
@ -925,7 +925,21 @@ module Net #:nodoc:
|
|||
end
|
||||
# Server Name Indication (SNI) RFC 3546
|
||||
s.hostname = @address if s.respond_to? :hostname=
|
||||
Timeout.timeout(@open_timeout, Net::OpenTimeout) { s.connect }
|
||||
if timeout = @open_timeout
|
||||
while true
|
||||
raise Net::OpenTimeout if timeout <= 0
|
||||
start = Process.clock_gettime Process::CLOCK_MONOTONIC
|
||||
# to_io is requied because SSLSocket doesn't have wait_readable yet
|
||||
case s.connect_nonblock(exception: false)
|
||||
when :wait_readable; s.to_io.wait_readable(timeout)
|
||||
when :wait_writable; s.to_io.wait_writable(timeout)
|
||||
else; break
|
||||
end
|
||||
timeout -= Process.clock_gettime(Process::CLOCK_MONOTONIC) - start
|
||||
end
|
||||
else
|
||||
s.connect
|
||||
end
|
||||
if @ssl_context.verify_mode != OpenSSL::SSL::VERIFY_NONE
|
||||
s.post_connection_check(@address)
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue