From 73c435118d403dddc867d6a718e01e3cac9384e9 Mon Sep 17 00:00:00 2001 From: yugui Date: Sat, 13 Dec 2008 01:03:08 +0000 Subject: merges r20630 from trunk into ruby_1_9_1. * test/ruby/test_io.rb (test_dup_many): extracted from test_dup. test in ruby subprocess. at asakusa.rb. [ruby-dev:35648] git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_9_1@20701 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- test/ruby/test_io.rb | 32 +++++++++++++++++++++----------- 1 file changed, 21 insertions(+), 11 deletions(-) (limited to 'test') diff --git a/test/ruby/test_io.rb b/test/ruby/test_io.rb index 34a8d017c..78cb425ed 100644 --- a/test/ruby/test_io.rb +++ b/test/ruby/test_io.rb @@ -651,18 +651,28 @@ class TestIO < Test::Unit::TestCase assert_equal("foo\nbar\n", f.read) assert_equal("", f2.read) end + end - a = [] - assert_raise(Errno::EMFILE, Errno::ENFILE, Errno::ENOMEM) do - loop {a << IO.pipe} - end - assert_raise(Errno::EMFILE, Errno::ENFILE, Errno::ENOMEM) do - loop {a << [a[-1][0].dup, a[-1][1].dup]} - end - a.each do |r, w| - r.close unless !r || r.closed? - w.close unless !w || w.closed? - end + def test_dup_many + ruby('-e', <<-'End') {|f| + ok = 0 + a = [] + begin + loop {a << IO.pipe} + rescue Errno::EMFILE, Errno::ENFILE, Errno::ENOMEM + ok += 1 + end + print "no" if ok != 1 + begin + loop {a << [a[-1][0].dup, a[-1][1].dup]} + rescue Errno::EMFILE, Errno::ENFILE, Errno::ENOMEM + ok += 1 + end + print "no" if ok != 2 + print "ok" + End + assert_equal("ok", f.read) + } end def test_inspect -- cgit