ruby-changes:21247
From: kosaki <ko1@a...>
Date: Mon, 19 Sep 2011 18:47:38 +0900 (JST)
Subject: [ruby-changes:21247] kosaki:r33296 (trunk): * test/-ext-/old_thread_select/test_old_thread_select.rb:
kosaki 2011-09-19 18:47:27 +0900 (Mon, 19 Sep 2011) New Revision: 33296 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=33296 Log: * test/-ext-/old_thread_select/test_old_thread_select.rb: select() with timeout may return early in old Linux kernels with 250 Hz tickrate and no dynticks, so skip everything older than 2.6.32 (which has long term support). And, Make the timing assertions consistently use assert_operator with timing difference in error message Patch by Eric Wong. [Bug #5335] [ruby-core:39618] Modified files: trunk/ChangeLog trunk/test/-ext-/old_thread_select/test_old_thread_select.rb Index: ChangeLog =================================================================== --- ChangeLog (revision 33295) +++ ChangeLog (revision 33296) @@ -1,3 +1,13 @@ +Mon Sep 19 18:42:58 2011 KOSAKI Motohiro <kosaki.motohiro@g...> + + * test/-ext-/old_thread_select/test_old_thread_select.rb: + select() with timeout may return early in old Linux kernels + with 250 Hz tickrate and no dynticks, so skip everything older + than 2.6.32 (which has long term support). + And, Make the timing assertions consistently use assert_operator with + timing difference in error message + Patch by Eric Wong. [Bug #5335] [ruby-core:39618] + Mon Sep 19 09:28:06 2011 Eric Hodel <drbrain@s...> * test/openssl/test_ssl.rb (class OpenSSL): Test Index: test/-ext-/old_thread_select/test_old_thread_select.rb =================================================================== --- test/-ext-/old_thread_select/test_old_thread_select.rb (revision 33295) +++ test/-ext-/old_thread_select/test_old_thread_select.rb (revision 33296) @@ -3,6 +3,8 @@ class TestOldThreadSelect < Test::Unit::TestCase require '-test-/old_thread_select/old_thread_select' + ANCIENT_LINUX = RUBY_PLATFORM =~ /linux/ && `uname -r`.chomp < '2.6.32' + def with_pipe r, w = IO.pipe begin @@ -19,9 +21,9 @@ rc = IO.old_thread_select([r.fileno], nil, nil, 0.001) diff = Time.now - t0 assert_equal 0, rc - assert_operator diff, :>=, 0.001, "returned too early" + assert_operator diff, :>=, 0.001, "returned too early: diff=#{diff}" end - end + end unless ANCIENT_LINUX def test_old_select_error_timeout bug5299 = '[ruby-core:39380]' @@ -30,9 +32,9 @@ rc = IO.old_thread_select(nil, nil, [r.fileno], 0.001) diff = Time.now - t0 assert_equal 0, rc, bug5299 - assert_operator diff, :>=, 0.001, "returned too early" + assert_operator diff, :>=, 0.001, "returned too early: diff=#{diff}" end - end + end unless ANCIENT_LINUX def test_old_select_false_positive bug5306 = '[ruby-core:39435]' @@ -76,15 +78,18 @@ end rc = nil - t0 = Time.now + diff = nil with_pipe do |r,w| assert_nothing_raised do + t0 = Time.now rc = IO.old_thread_select([r.fileno], nil, nil, 1) + diff = Time.now - t0 end end - diff = Time.now - t0 - assert_operator diff, :>=, 1.0, "interrupted or short wait" + unless ANCIENT_LINUX + assert_operator diff, :>=, 1, "interrupted or short wait: diff=#{diff}" + end assert_equal 0, rc assert_equal true, thr.value assert_not_equal false, received, "SIGINT not received" -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/