2008-01-07 18:32:07 +03:00
|
|
|
require 'test/unit'
|
|
|
|
require 'timeout'
|
|
|
|
require 'thread'
|
|
|
|
|
|
|
|
class TestTimeout < Test::Unit::TestCase
|
|
|
|
def test_queue
|
|
|
|
q = Queue.new
|
|
|
|
assert_raise(Timeout::Error, "[ruby-dev:32935]") {
|
|
|
|
timeout(0.1) { q.pop }
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2009-04-28 14:10:05 +04:00
|
|
|
def test_timeout
|
|
|
|
@flag = true
|
|
|
|
Thread.start {
|
|
|
|
sleep 0.1
|
|
|
|
@flag = false
|
|
|
|
}
|
|
|
|
assert_nothing_raised("[ruby-dev:38319]") do
|
|
|
|
Timeout.timeout(1) {
|
2012-12-07 14:36:59 +04:00
|
|
|
nil while @flag
|
2009-04-28 14:10:05 +04:00
|
|
|
}
|
|
|
|
end
|
|
|
|
assert !@flag, "[ruby-dev:38319]"
|
|
|
|
end
|
2010-04-19 13:58:09 +04:00
|
|
|
|
|
|
|
def test_cannot_convert_into_time_interval
|
|
|
|
bug3168 = '[ruby-dev:41010]'
|
|
|
|
def (n = Object.new).zero?; false; end
|
|
|
|
assert_raise(TypeError, bug3168) {Timeout.timeout(n) { sleep 0.1 }}
|
|
|
|
end
|
2013-08-26 10:27:48 +04:00
|
|
|
|
|
|
|
def test_skip_rescue
|
|
|
|
bug8730 = '[Bug #8730]'
|
|
|
|
e = nil
|
2013-08-27 12:18:50 +04:00
|
|
|
assert_raise_with_message(Timeout::Error, /execution expired/, bug8730) do
|
2013-08-26 10:27:48 +04:00
|
|
|
timeout 0.1 do
|
|
|
|
begin
|
|
|
|
sleep 3
|
|
|
|
rescue Exception => e
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
assert_nil(e, bug8730)
|
|
|
|
end
|
2013-08-27 12:18:50 +04:00
|
|
|
|
|
|
|
def test_rescue_exit
|
|
|
|
exc = Class.new(RuntimeError)
|
|
|
|
e = nil
|
|
|
|
assert_nothing_raised(exc) do
|
|
|
|
timeout 0.1, exc do
|
|
|
|
begin
|
|
|
|
sleep 3
|
|
|
|
rescue exc => e
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
assert_raise_with_message(exc, /execution expired/) {raise e if e}
|
|
|
|
end
|
2009-04-28 14:10:05 +04:00
|
|
|
end
|