* test/ruby/envutil.rb (assert_normal_exit): capture stdout and stderr
of the child process. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@16520 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
9d27c792c2
commit
a85b247171
@ -1,3 +1,8 @@
|
|||||||
|
Thu May 22 11:39:59 2008 Tanaka Akira <akr@fsij.org>
|
||||||
|
|
||||||
|
* test/ruby/envutil.rb (assert_normal_exit): capture stdout and stderr
|
||||||
|
of the child process.
|
||||||
|
|
||||||
Thu May 22 08:28:49 2008 Yukihiro Matsumoto <matz@ruby-lang.org>
|
Thu May 22 08:28:49 2008 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
|
|
||||||
* array.c (flatten): free memo hash table before raising exception.
|
* array.c (flatten): free memo hash table before raising exception.
|
||||||
|
@ -72,9 +72,16 @@ module Test
|
|||||||
module Assertions
|
module Assertions
|
||||||
public
|
public
|
||||||
def assert_normal_exit(testsrc, message = '')
|
def assert_normal_exit(testsrc, message = '')
|
||||||
IO.popen([EnvUtil.rubybin, '-W0'], 'w') {|io|
|
in_c, in_p = IO.pipe
|
||||||
io.write testsrc
|
out_p, out_c = IO.pipe
|
||||||
}
|
pid = spawn(EnvUtil.rubybin, '-W0', STDIN=>in_c, STDOUT=>out_c, STDERR=>out_c)
|
||||||
|
in_c.close
|
||||||
|
out_c.close
|
||||||
|
in_p.write testsrc
|
||||||
|
in_p.close
|
||||||
|
msg = out_p.read
|
||||||
|
out_p.close
|
||||||
|
Process.wait pid
|
||||||
status = $?
|
status = $?
|
||||||
faildesc = nil
|
faildesc = nil
|
||||||
if status.signaled?
|
if status.signaled?
|
||||||
@ -84,9 +91,20 @@ module Test
|
|||||||
if signame
|
if signame
|
||||||
sigdesc = "SIG#{signame} (#{sigdesc})"
|
sigdesc = "SIG#{signame} (#{sigdesc})"
|
||||||
end
|
end
|
||||||
full_message = build_message(message, "killed by ?", sigdesc)
|
if msg.empty?
|
||||||
|
full_message = build_message(message, "killed by ?", sigdesc)
|
||||||
|
else
|
||||||
|
msg << "\n" if /\n\z/ !~ msg
|
||||||
|
full_message = build_message(message, "killed by ?\n?", sigdesc,
|
||||||
|
AssertionMessage::Literal.new(msg.gsub(/^/, '| ')))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
assert_block(full_message) { !status.signaled? }
|
assert_block(full_message) { !status.signaled? }
|
||||||
|
ensure
|
||||||
|
in_c.close if in_c && !in_c.closed?
|
||||||
|
in_p.close if in_p && !in_p.closed?
|
||||||
|
out_c.close if out_c && !out_c.closed?
|
||||||
|
out_p.close if out_p && !out_p.closed?
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -51,5 +51,17 @@ class TestContinuation < Test::Unit::TestCase
|
|||||||
c.call
|
c.call
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_ary_flatten
|
||||||
|
assert_normal_exit %q{
|
||||||
|
require 'continuation'
|
||||||
|
n = 0
|
||||||
|
o = Object.new
|
||||||
|
def o.to_ary() callcc {|k| $k = k; [1,2,3]} end
|
||||||
|
[10,20,o,30,o,40].flatten.inspect
|
||||||
|
n += 1
|
||||||
|
$k.call if n < 100
|
||||||
|
}, '[ruby-dev:34798]'
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user