Backport #3170
closedtimeout() does'nt work with Non Integer/Float Argument
Description
=begin
Ruby 1.8.7p248で、timeout()の引数にIntegerやFloat以外のオブジェクトを渡すと、
何も起こらないままタイムアウトが効かなくなります。
あまり機会はありませんが、
- Rational(mathnをrequireしたあと、1/2秒など指定すると困る)や、
- ActiveSupport::Duration(10.secondsなどで返る)
でタイムアウト秒を指定する場合にはまってしまいます。
原因は、timeout()で作られる監視用スレッドyにて、sleepがTypeErrorを起こし、yがすぐに
終了してしまうのが原因だと思っています。
数値に変換できそうなオブジェクトの場合は、to_i/to_fしてsleepする挙動か、
もしくは明示的に例外があがるようになれば助かりますが、いかがでしょうか。
$ ruby -v -rtimeout -rrational -e 'timeout(Rational(1,2)){ sleep 3; p "slept" }'
ruby 1.8.7 (2009-12-24 patchlevel 248) [i686-darwin9]
"slept"
$ ruby19 -v -rtimeout -rrational -e 'timeout(Rational(1,2)){ sleep 3; p "slept!" }'
ruby 1.9.2dev (2009-09-25 trunk 25091) [i386-darwin9]
lib/rational.rb is deprecated
-e:1:in sleep': execution expired (Timeout::Error) from -e:1:in
block in '
from -e:1:in `'
=end
Updated by moro (Kyosuke MOROHASHI) over 14 years ago
=begin
[Bug #3168]で修正済みのものですね。すみません。
お手数をおかけしてすみませんが、閉じてください。
=end
Updated by shyouhei (Shyouhei Urabe) over 14 years ago
- Status changed from Open to Closed
=begin
=end