diff options
author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2014-07-07 04:08:55 +0000 |
---|---|---|
committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2014-07-07 04:08:55 +0000 |
commit | 79d578ebe7656d847fdc8e898ffa081e4754a8a4 (patch) | |
tree | 0c153645371a9e25d4fe8976fdc7eac534269e80 /test/ruby | |
parent | a383ffa07b4641f6e19500e95cf9388af05e510c (diff) |
merge revision(s) 46159,46196: [Backport #8523]
* test/test_timeout.rb (test_timeout): inverted test condition.
[Bug #8523]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@46748 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/ruby')
-rw-r--r-- | test/ruby/test_thread.rb | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/test/ruby/test_thread.rb b/test/ruby/test_thread.rb index 1e730a1452..a05123f81d 100644 --- a/test/ruby/test_thread.rb +++ b/test/ruby/test_thread.rb @@ -363,6 +363,24 @@ class TestThread < Test::Unit::TestCase c.kill if c end + def test_switch_while_busy_loop + bug1402 = "[ruby-dev:38319] [Bug #1402]" + flag = true + th = Thread.current + waiter = Thread.start { + sleep 0.1 + flag = false + sleep 1 + th.raise(bug1402) + } + assert_nothing_raised(RuntimeError, bug1402) do + nil while flag + end + assert(!flag, bug1402) + ensure + waiter.kill.join + end + def test_safe_level t = Thread.new { $SAFE = 3; sleep } sleep 0.5 |