2011-08-29 20:33:05 -04:00
|
|
|
require 'test/unit'
|
|
|
|
|
|
|
|
class TestOldThreadSelect < Test::Unit::TestCase
|
|
|
|
require '-test-/old_thread_select/old_thread_select'
|
|
|
|
|
2011-09-19 05:47:27 -04:00
|
|
|
ANCIENT_LINUX = RUBY_PLATFORM =~ /linux/ && `uname -r`.chomp < '2.6.32'
|
2012-01-07 11:22:47 -05:00
|
|
|
DARWIN_10 = RUBY_PLATFORM =~ /darwin10/
|
2011-09-19 05:47:27 -04:00
|
|
|
|
2011-08-29 20:33:05 -04:00
|
|
|
def with_pipe
|
|
|
|
r, w = IO.pipe
|
|
|
|
begin
|
|
|
|
yield r, w
|
|
|
|
ensure
|
|
|
|
r.close unless r.closed?
|
|
|
|
w.close unless w.closed?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_old_select_read_timeout
|
|
|
|
with_pipe do |r, w|
|
|
|
|
t0 = Time.now
|
|
|
|
rc = IO.old_thread_select([r.fileno], nil, nil, 0.001)
|
|
|
|
diff = Time.now - t0
|
|
|
|
assert_equal 0, rc
|
2011-09-19 05:47:27 -04:00
|
|
|
assert_operator diff, :>=, 0.001, "returned too early: diff=#{diff}"
|
2011-08-29 20:33:05 -04:00
|
|
|
end
|
2011-09-19 05:47:27 -04:00
|
|
|
end unless ANCIENT_LINUX
|
2011-08-29 20:33:05 -04:00
|
|
|
|
2011-09-08 21:22:06 -04:00
|
|
|
def test_old_select_error_timeout
|
|
|
|
bug5299 = '[ruby-core:39380]'
|
|
|
|
with_pipe do |r, w|
|
|
|
|
t0 = Time.now
|
|
|
|
rc = IO.old_thread_select(nil, nil, [r.fileno], 0.001)
|
|
|
|
diff = Time.now - t0
|
|
|
|
assert_equal 0, rc, bug5299
|
2011-09-19 05:47:27 -04:00
|
|
|
assert_operator diff, :>=, 0.001, "returned too early: diff=#{diff}"
|
2011-09-08 21:22:06 -04:00
|
|
|
end
|
2011-09-19 05:47:27 -04:00
|
|
|
end unless ANCIENT_LINUX
|
2011-09-08 21:22:06 -04:00
|
|
|
|
2011-09-12 07:36:06 -04:00
|
|
|
def test_old_select_false_positive
|
|
|
|
bug5306 = '[ruby-core:39435]'
|
|
|
|
with_pipe do |r2, w2|
|
|
|
|
with_pipe do |r, w|
|
|
|
|
t0 = Time.now
|
|
|
|
w.syswrite '.'
|
|
|
|
rfds = [ r.fileno, r2.fileno ]
|
|
|
|
rc = IO.old_thread_select(rfds, nil, nil, nil)
|
|
|
|
assert_equal [ r.fileno ], rfds, bug5306
|
|
|
|
assert_equal 1, rc, bug5306
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-08-29 20:33:05 -04:00
|
|
|
def test_old_select_read_write_check
|
|
|
|
with_pipe do |r, w|
|
|
|
|
w.syswrite('.')
|
|
|
|
rc = IO.old_thread_select([r.fileno], nil, nil, nil)
|
|
|
|
assert_equal 1, rc
|
|
|
|
|
|
|
|
rc = IO.old_thread_select([r.fileno], [w.fileno], nil, nil)
|
|
|
|
assert_equal 2, rc
|
|
|
|
|
|
|
|
assert_equal '.', r.read(1)
|
|
|
|
|
|
|
|
rc = IO.old_thread_select([r.fileno], [w.fileno], nil, nil)
|
|
|
|
assert_equal 1, rc
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_old_select_signal_safe
|
|
|
|
return unless Process.respond_to?(:kill)
|
2011-08-30 11:07:21 -04:00
|
|
|
received = false
|
|
|
|
trap(:INT) { received = true }
|
2011-08-29 20:33:05 -04:00
|
|
|
main = Thread.current
|
|
|
|
thr = Thread.new do
|
|
|
|
Thread.pass until main.stop?
|
2011-08-30 11:07:21 -04:00
|
|
|
Process.kill(:INT, $$)
|
2011-08-29 20:33:05 -04:00
|
|
|
true
|
|
|
|
end
|
|
|
|
|
|
|
|
rc = nil
|
2011-09-19 05:47:27 -04:00
|
|
|
diff = nil
|
2011-08-29 20:33:05 -04:00
|
|
|
with_pipe do |r,w|
|
|
|
|
assert_nothing_raised do
|
2011-09-19 05:47:27 -04:00
|
|
|
t0 = Time.now
|
2011-08-29 20:33:05 -04:00
|
|
|
rc = IO.old_thread_select([r.fileno], nil, nil, 1)
|
2011-09-19 05:47:27 -04:00
|
|
|
diff = Time.now - t0
|
2011-08-29 20:33:05 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-01-07 11:22:47 -05:00
|
|
|
unless ANCIENT_LINUX || DARWIN_10
|
2011-09-19 05:47:27 -04:00
|
|
|
assert_operator diff, :>=, 1, "interrupted or short wait: diff=#{diff}"
|
|
|
|
end
|
2011-08-29 20:33:05 -04:00
|
|
|
assert_equal 0, rc
|
|
|
|
assert_equal true, thr.value
|
2011-09-06 04:11:21 -04:00
|
|
|
assert_not_equal false, received, "SIGINT not received"
|
2011-09-08 21:22:06 -04:00
|
|
|
ensure
|
|
|
|
trap(:INT, "DEFAULT")
|
2011-08-29 20:33:05 -04:00
|
|
|
end
|
|
|
|
end
|