[前][次][番号順一覧][スレッド一覧]

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/

[前][次][番号順一覧][スレッド一覧]