diff --git a/ChangeLog b/ChangeLog index ba1af7bc91..31bf172669 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,4 +1,7 @@ -Thu Apr 14 22:47:49 2011 Nobuyoshi Nakada +Thu Apr 14 22:47:54 2011 Nobuyoshi Nakada + + * lib/test/unit.rb (Test::Unit::Runner#_run_parallel): check if worker + is signaled and use its exit status. * lib/test/unit.rb (Test::Unit::Runner::Worker#dead): no longer @in and @out are separated. diff --git a/lib/test/unit.rb b/lib/test/unit.rb index 6fba30043a..6db79213a3 100644 --- a/lib/test/unit.rb +++ b/lib/test/unit.rb @@ -329,7 +329,7 @@ module Test @@installed_at_exit = true end - def after_worker_down(worker, e=nil, c=1) + def after_worker_down(worker, e=nil, c=false) return unless @opts[:parallel] return if @interrupt if e @@ -404,11 +404,12 @@ module Test watchdog = Thread.new do while stat = Process.wait2 break if @interrupt # Break when interrupt - w = (@workers + @dead_workers).find{|x| stat[0] == x.pid }.dup + pid, stat = stat + w = (@workers + @dead_workers).find{|x| pid == x.pid }.dup next unless w unless w.status == :quit # Worker down - w.dead(nil, stat[1].to_i) + w.dead(nil, !stat.signaled? && stat.exitstatus) end end end