summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormarcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-09-26 04:27:07 +0000
committermarcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-09-26 04:27:07 +0000
commit182e4f0eb100b51cc8f29691ecbf23ec71042dbb (patch)
tree745f1ba1ceb379d21be0d53b07a0a4a1b928ee1a
parentb3707539ed3a1a7a9525c650fc871dfd57209732 (diff)
downloadruby-182e4f0eb100b51cc8f29691ecbf23ec71042dbb.tar.gz
ruby-182e4f0eb100b51cc8f29691ecbf23ec71042dbb.tar.xz
ruby-182e4f0eb100b51cc8f29691ecbf23ec71042dbb.zip
* lib/net/http.rb (transport_request): Handle timeout error by closing socket if exception raised. [ruby-core:20976]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@25097 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--lib/net/http.rb4
2 files changed, 9 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 02e3cc6ca..b3cd1585f 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Sat Sep 26 13:26:55 2009 Marc-Andre Lafortune <ruby-core@marc-andre.ca>
+
+ * lib/net/http.rb (transport_request): Handle timeout error by
+ closing socket if exception raised. [ruby-core:20976]
+
Sat Sep 26 08:35:12 2009 Koichi Sasada <ko1@atdot.net>
* iseq.c (compile_string): rename to parse_string(), because
diff --git a/lib/net/http.rb b/lib/net/http.rb
index 512391b19..64dbef4cb 100644
--- a/lib/net/http.rb
+++ b/lib/net/http.rb
@@ -1124,6 +1124,10 @@ module Net #:nodoc:
}
end_transport req, res
res
+ rescue => exception
+ D "Conn close because of error #{exception}"
+ @socket.close unless @socket.closed?
+ raise exception
end
def begin_transport(req)