[#53944] [ruby-trunk - Bug #8210][Open] Multibyte character interfering with end-line character within a regex — "sawa (Tsuyoshi Sawada)" <sawadatsuyoshi@...>

14 messages 2013/04/03

[#53974] [ruby-trunk - Feature #8215][Open] Support accessing Fiber-locals and backtraces for a Fiber — "halorgium (Tim Carey-Smith)" <ruby-lang-bugs@...>

14 messages 2013/04/03

[#54095] [ruby-trunk - Feature #8237][Open] Logical method chaining via inferred receiver — "wardrop (Tom Wardrop)" <tom@...>

34 messages 2013/04/08

[#54138] [ruby-trunk - Bug #8241][Open] If uri host-part has underscore ( '_' ), 'URI#parse' raise 'URI::InvalidURIError' — "neocoin (Sangmin Ryu)" <neocoin@...>

9 messages 2013/04/09

[#54185] [CommonRuby - Feature #8257][Open] Exception#cause to carry originating exception along with new one — "headius (Charles Nutter)" <headius@...>

43 messages 2013/04/11

[#54196] Encouraging use of CommonRuby — Charles Oliver Nutter <headius@...>

I think we need to do more to encourage the use of the CommonRuby

20 messages 2013/04/11
[#54200] Re: Encouraging use of CommonRuby — Marc-Andre Lafortune <ruby-core-mailing-list@...> 2013/04/11

Hi,

[#54211] Re: Encouraging use of CommonRuby — "NARUSE, Yui" <naruse@...> 2013/04/12

As far as I understand, what is CommonRuby and the process over CommonRuby

[#54215] Re: Encouraging use of CommonRuby — Charles Oliver Nutter <headius@...> 2013/04/12

On Thu, Apr 11, 2013 at 11:25 PM, NARUSE, Yui <naruse@airemix.jp> wrote:

[#54207] [CommonRuby - Feature #8258][Open] Dir#escape_glob — "steveklabnik (Steve Klabnik)" <steve@...>

15 messages 2013/04/12

[#54218] [CommonRuby - Feature #8259][Open] Atomic attributes accessors — "funny_falcon (Yura Sokolov)" <funny.falcon@...>

43 messages 2013/04/12

[#54288] [CommonRuby - Feature #8271][Open] Proposal for moving to a more visible, formal process for feature requests — "headius (Charles Nutter)" <headius@...>

15 messages 2013/04/15

[#54333] Requesting Commit Access — Aman Gupta <ruby@...1.net>

Hello ruby-core,

16 messages 2013/04/16

[#54473] [Backport 200 - Backport #8299][Open] Minor error in float parsing — "bobjalex (Bob Alexander)" <bobjalex@...>

27 messages 2013/04/19

[#54532] [ruby-trunk - Bug #8315][Open] mkmf does not include include paths from pkg_config anymore — "Hanmac (Hans Mackowiak)" <hanmac@...>

11 messages 2013/04/23

[#54621] [ruby-trunk - Feature #8339][Open] Introducing Geneartional Garbage Collection for CRuby/MRI — "ko1 (Koichi Sasada)" <redmine@...>

43 messages 2013/04/27
[#54643] [ruby-trunk - Feature #8339] Introducing Geneartional Garbage Collection for CRuby/MRI — "authorNari (Narihiro Nakamura)" <authorNari@...> 2013/04/28

[#54649] Re: [ruby-trunk - Feature #8339] Introducing Geneartional Garbage Collection for CRuby/MRI — SASADA Koichi <ko1@...> 2013/04/28

(2013/04/28 9:23), authorNari (Narihiro Nakamura) wrote:

[#54657] Re: [ruby-trunk - Feature #8339][Open] Introducing Geneartional Garbage Collection for CRuby/MRI — Magnus Holm <judofyr@...> 2013/04/28

On Sat, Apr 27, 2013 at 8:19 PM, ko1 (Koichi Sasada)

[#54665] [ruby-trunk - Bug #8344][Open] Status of Psych and Syck — "Eregon (Benoit Daloze)" <redmine@...>

18 messages 2013/04/28

[ruby-core:54087] [ruby-trunk - Bug #8067] Checking a network connection in a loop never succeeds even if the connection is available.

From: "steakknife (Barry Allard)" <barry.allard@...>
Date: 2013-04-07 20:22:26 UTC
List: ruby-core #54087
Issue #8067 has been updated by steakknife (Barry Allard).


Modified a bit for interactive looping:

    #!/usr/bin/env ruby
    require 'net/http'

    loop do
      sleep 1
      begin
        uri = URI.parse 'http://www.example.com'
        resp = Net::HTTP.get uri
        puts 'It works!'
      rescue SocketError => se
        puts se
        next
      rescue Exception => e
        puts e
        next
      end
    end


Mac (10.7.5 + 1.9.3-p392) output:

    It works!
    It works!
    It works!
    It works!
    It works!
    No route to host - connect(2)
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    It works!
    It works!
    It works!
    It works!
    No route to host - connect(2)
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    getaddrinfo: nodename nor servname provided, or not known
    It works!
    It works!
    It works!
    ^C
    It works!
    It works!
    ^C./net_test.rb:5:in `sleep': Interrupt
            from ./net_test.rb:5:in `block in <main>'
            from ./net_test.rb:4:in `loop'
            from ./net_test.rb:4:in `<main>'

Haven't tried Linux or FreeBSD yet.
----------------------------------------
Bug #8067: Checking a network connection in a loop never succeeds even if the connection is available.
https://bugs.ruby-lang.org/issues/8067#change-38339

Author: l0x (Markus Lux)
Status: Open
Priority: Normal
Assignee: 
Category: 
Target version: 
ruby -v: ruby 2.0.0p0 (2013-02-24 revision 39474) [x86_64-linux]


=begin
I want to check for a connection to a specific server with Ruby. So I just wrap the HTTP request into a begin/rescue construct and try again in a few seconds if the connection is not available.

((*Problem*)): If I start the program with no connection available (link down) it will never succeed in finding a connection even if at some time the connection is available (e.g. via ping, browser request).

((*Test case:*)) 

 require 'net/http'
 
 loop do 
 
 	begin
 		uri = URI.parse 'http://www.example.com'
 		resp = Net::HTTP.get uri
 	rescue SocketError => se
 		puts se
 		sleep 3
 		next
 	rescue Exception => e
 		puts e
 		break	
 	end
 
 	puts 'It works!'
 	break
 
 end

((*Steps to reproduce:*))

(1) Take network link down
(2) Start program
(3) -> getaddrinfo: Name or service not known
(4) -> ...
(5) Turn network link on again
(6) Still no connection, same error

((*Expected behavior:*)) Don't throw SocketException as soon as a connection is available.

((*Ruby versions tested:*))

ruby 1.9.3p392 (2013-02-22 revision 39386) [x86_64-linux]

ruby 2.0.0p0 (2013-02-24 revision 39474) [x86_64-linux]

This may only affect Linux since there exist reports on [1] where people commented that the program works as expected on Windows and Mac.

[1] http://stackoverflow.com/questions/15321260/checking-a-network-connection-in-a-loop-never-succeeds-even-if-the-connection-is

=end


-- 
http://bugs.ruby-lang.org/

In This Thread