2015-12-16 08:07:31 +03:00
|
|
|
# frozen_string_literal: false
|
2008-01-07 18:32:07 +03:00
|
|
|
require 'test/unit'
|
|
|
|
require 'timeout'
|
|
|
|
require 'thread'
|
|
|
|
|
|
|
|
class TestTimeout < Test::Unit::TestCase
|
|
|
|
def test_queue
|
2016-08-30 09:22:30 +03:00
|
|
|
q = Thread::Queue.new
|
2008-01-07 18:32:07 +03:00
|
|
|
assert_raise(Timeout::Error, "[ruby-dev:32935]") {
|
2015-07-13 13:07:01 +03:00
|
|
|
Timeout.timeout(0.01) { q.pop }
|
2008-01-07 18:32:07 +03:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2009-04-28 14:10:05 +04:00
|
|
|
def test_timeout
|
2014-05-28 07:05:48 +04:00
|
|
|
assert_raise(Timeout::Error) do
|
2014-05-27 12:00:19 +04:00
|
|
|
Timeout.timeout(0.1) {
|
2014-05-28 07:05:48 +04:00
|
|
|
nil while true
|
2009-04-28 14:10:05 +04:00
|
|
|
}
|
|
|
|
end
|
|
|
|
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
|
2015-07-13 13:07:01 +03:00
|
|
|
Timeout.timeout 0.01 do
|
2013-08-26 10:27:48 +04:00
|
|
|
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
|
2015-07-13 13:07:01 +03:00
|
|
|
Timeout.timeout 0.01, exc do
|
2013-08-27 12:18:50 +04:00
|
|
|
begin
|
|
|
|
sleep 3
|
|
|
|
rescue exc => e
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2015-11-03 15:15:31 +03:00
|
|
|
assert_raise_with_message(exc, 'execution expired') {raise e if e}
|
2013-08-27 12:18:50 +04:00
|
|
|
end
|
2014-01-07 07:42:37 +04:00
|
|
|
|
|
|
|
def test_custom_exception
|
|
|
|
bug9354 = '[ruby-core:59511] [Bug #9354]'
|
|
|
|
err = Class.new(StandardError) do
|
|
|
|
def initialize(msg) super end
|
|
|
|
end
|
|
|
|
assert_nothing_raised(ArgumentError, bug9354) do
|
2015-07-13 13:07:01 +03:00
|
|
|
assert_equal(:ok, Timeout.timeout(100, err) {:ok})
|
2014-01-07 07:42:37 +04:00
|
|
|
end
|
2015-11-03 15:15:31 +03:00
|
|
|
assert_raise_with_message(err, 'execution expired') do
|
2015-07-13 13:07:01 +03:00
|
|
|
Timeout.timeout 0.01, err do
|
2015-07-11 02:47:55 +03:00
|
|
|
sleep 3
|
|
|
|
end
|
|
|
|
end
|
2016-09-07 15:32:04 +03:00
|
|
|
assert_raise_with_message(err, /connection to ruby-lang.org expired/) do
|
|
|
|
Timeout.timeout 0.01, err, "connection to ruby-lang.org expired" do
|
2016-09-07 11:21:56 +03:00
|
|
|
sleep 3
|
|
|
|
end
|
|
|
|
end
|
2014-01-07 07:42:37 +04:00
|
|
|
end
|
2014-01-07 07:43:08 +04:00
|
|
|
|
|
|
|
def test_exit_exception
|
2015-07-10 16:05:53 +03:00
|
|
|
assert_raise_with_message(Timeout::Error, "boon") do
|
|
|
|
Timeout.timeout(10, Timeout::Error) do
|
|
|
|
raise Timeout::Error, "boon"
|
2014-01-07 07:43:08 +04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2014-01-08 08:12:39 +04:00
|
|
|
|
|
|
|
def test_enumerator_next
|
|
|
|
bug9380 = '[ruby-dev:47872] [Bug #9380]: timeout in Enumerator#next'
|
|
|
|
e = (o=Object.new).to_enum
|
|
|
|
def o.each
|
|
|
|
sleep
|
|
|
|
end
|
|
|
|
assert_raise_with_message(Timeout::Error, 'execution expired', bug9380) do
|
|
|
|
Timeout.timeout(0.01) {e.next}
|
|
|
|
end
|
|
|
|
end
|
2015-07-10 16:05:53 +03:00
|
|
|
|
|
|
|
def test_handle_interrupt
|
|
|
|
bug11344 = '[ruby-dev:49179] [Bug #11344]'
|
|
|
|
ok = false
|
|
|
|
assert_raise(Timeout::Error) {
|
|
|
|
Thread.handle_interrupt(Timeout::Error => :never) {
|
|
|
|
Timeout.timeout(0.01) {
|
|
|
|
sleep 0.2
|
|
|
|
ok = true
|
|
|
|
Thread.handle_interrupt(Timeout::Error => :on_blocking) {
|
|
|
|
sleep 0.2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
assert(ok, bug11344)
|
|
|
|
end
|
2009-04-28 14:10:05 +04:00
|
|
|
end
|