aboutsummaryrefslogtreecommitdiffstats
path: root/test/ruby/test_thread.rb
diff options
context:
space:
mode:
authornaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-10-28 18:58:34 +0000
committernaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-10-28 18:58:34 +0000
commit875b7d9e6638abdef05ca47dd471390dac6eafa6 (patch)
treeb366d206c591d6fb6235349e4d992bb3280f6fa8 /test/ruby/test_thread.rb
parent1dcd94df24b47983c3c723c7196463db326f4156 (diff)
downloadruby-875b7d9e6638abdef05ca47dd471390dac6eafa6.tar.gz
thread may leak if assert fails before join is finished
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52330 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/ruby/test_thread.rb')
-rw-r--r--test/ruby/test_thread.rb5
1 files changed, 3 insertions, 2 deletions
diff --git a/test/ruby/test_thread.rb b/test/ruby/test_thread.rb
index ddbbaf2c63..48a6bd2e38 100644
--- a/test/ruby/test_thread.rb
+++ b/test/ruby/test_thread.rb
@@ -637,7 +637,7 @@ class TestThread < Test::Unit::TestCase
th = Thread.start{
Thread.handle_interrupt(Object => :on_blocking){
begin
- sleep 0.0001 until r == :wait
+ Thread.pass until r == :wait
Thread.current.raise RuntimeError
r = :ok
sleep
@@ -647,8 +647,9 @@ class TestThread < Test::Unit::TestCase
}
}
assert_raise(e) {r = :wait; sleep 1}
- ensure
assert_raise(RuntimeError) {th.join(0)}
+ ensure
+ th.kill
end
assert_equal(:ok,r)
end