summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-06-24 02:00:15 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-06-24 02:00:15 +0000
commit9694e07f555d3bd3c7d2a41777290fa9fc181d52 (patch)
tree48fb66f0b6f6a8ec1f5213c0ea1bf45a52b51dc9 /test
parent55f1a19451e5fab7e1085a7ae29dfdb96ef3f775 (diff)
merges r28330 from trunk into ruby_1_9_2.
-- * test/ruby/test_io.rb (safe_4): does not use Timeout because Timeout.timeout uses Thread#kill which raises SecurityError when $SAFE == 4. based on a patch from Tomoyuki Chikanaga. [ruby-dev:41484] * test/ruby/test_io.rb (test_print_separators): use pipe (test helper method) instead of IO.pipe. [ruby-dev:41484] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_2@28419 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test')
-rw-r--r--test/ruby/test_io.rb33
1 files changed, 18 insertions, 15 deletions
diff --git a/test/ruby/test_io.rb b/test/ruby/test_io.rb
index 57a7c7c9a4..41d3640105 100644
--- a/test/ruby/test_io.rb
+++ b/test/ruby/test_io.rb
@@ -740,12 +740,14 @@ class TestIO < Test::Unit::TestCase
end
def safe_4
- Thread.new do
- Timeout.timeout(10) do
- $SAFE = 4
- yield
- end
- end.join
+ t = Thread.new do
+ $SAFE = 4
+ yield
+ end
+ unless t.join(10)
+ t.kill
+ flunk("timeout in safe_4")
+ end
end
def pipe(wp, rp)
@@ -1461,15 +1463,16 @@ End
def test_print_separators
$, = ':'
$\ = "\n"
- r, w = IO.pipe
- w.print('a')
- w.print('a','b','c')
- w.close
- assert_equal("a\n", r.gets)
- assert_equal("a:b:c\n", r.gets)
- assert_nil r.gets
- r.close
-
+ pipe(proc do |w|
+ w.print('a')
+ w.print('a','b','c')
+ w.close
+ end, proc do |r|
+ assert_equal("a\n", r.gets)
+ assert_equal("a:b:c\n", r.gets)
+ assert_nil r.gets
+ r.close
+ end)
ensure
$, = nil
$\ = nil