From: "nobu (Nobuyoshi Nakada)" Date: 2014-01-08T12:46:01+09:00 Subject: [ruby-dev:47872] [ruby-trunk - Bug #9380][Assigned] Enumerator does not work in timeout Issue #9380 has been reported by nobu (Nobuyoshi Nakada). ---------------------------------------- Bug #9380: Enumerator does not work in timeout https://bugs.ruby-lang.org/issues/9380 Author: nobu (Nobuyoshi Nakada) Status: Assigned Priority: Normal Assignee: nobu (Nobuyoshi Nakada) Category: lib Target version: current: 2.2.0 ruby -v: r44522 Backport: 1.9.3: UNKNOWN, 2.0.0: UNKNOWN, 2.1: UNKNOWN Enumeratorとtimeoutの組み合わせで、Timeout::Errorが起きるべきところでArgumentErrorが発生します。 $ ruby -v -rtimeout -e 'def (o=Object.new).each; sleep; end' -e 'Timeout.timeout(0.01) {o.to_enum.next}' ruby 2.2.0dev (2014-01-07 trunk 44522) [universal.x86_64-darwin13.0] /opt/local/lib/ruby/2.2.0/timeout.rb:39:in `throw': uncaught throw # (ArgumentError) from /opt/local/lib/ruby/2.2.0/timeout.rb:39:in `exception' from -e:1:in `sleep' from -e:1:in `each' from -e:1:in `each' -- http://bugs.ruby-lang.org/