mirror of
https://github.com/ruby/ruby.git
synced 2025-08-26 06:25:31 +02:00
unrevert r63852 but keep SIGCHLD path disabled for win32
Reading win32/win32.c waitpid implementation, maybe waitpid(-1, ...) on that platform will never conflict with mjit use of waitpid. In any case, I've added WAITPID_USE_SIGCHLD macro to vm_core.h so it can be easy for Linux/BSD users to test (hopefully!) win32-compatible code. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@63855 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
b3799b93c2
commit
44fc3d08eb
16 changed files with 632 additions and 235 deletions
|
@ -1426,7 +1426,6 @@ class TestProcess < Test::Unit::TestCase
|
|||
end
|
||||
|
||||
def test_wait_without_arg
|
||||
skip "[Bug #14867]" if RubyVM::MJIT.enabled?
|
||||
with_tmpchdir do
|
||||
write_file("foo", "sleep 0.1")
|
||||
pid = spawn(RUBY, "foo")
|
||||
|
@ -1435,7 +1434,6 @@ class TestProcess < Test::Unit::TestCase
|
|||
end
|
||||
|
||||
def test_wait2
|
||||
skip "[Bug #14867]" if RubyVM::MJIT.enabled?
|
||||
with_tmpchdir do
|
||||
write_file("foo", "sleep 0.1")
|
||||
pid = spawn(RUBY, "foo")
|
||||
|
@ -1444,7 +1442,6 @@ class TestProcess < Test::Unit::TestCase
|
|||
end
|
||||
|
||||
def test_waitall
|
||||
skip "[Bug #14867]" if RubyVM::MJIT.enabled?
|
||||
with_tmpchdir do
|
||||
write_file("foo", "sleep 0.1")
|
||||
ps = (0...3).map { spawn(RUBY, "foo") }.sort
|
||||
|
@ -1459,7 +1456,9 @@ class TestProcess < Test::Unit::TestCase
|
|||
def test_wait_exception
|
||||
bug11340 = '[ruby-dev:49176] [Bug #11340]'
|
||||
t0 = t1 = nil
|
||||
IO.popen([RUBY, '-e', 'puts;STDOUT.flush;Thread.start{gets;exit};sleep(3)'], 'r+') do |f|
|
||||
sec = 3
|
||||
code = "puts;STDOUT.flush;Thread.start{gets;exit};sleep(#{sec})"
|
||||
IO.popen([RUBY, '-e', code], 'r+') do |f|
|
||||
pid = f.pid
|
||||
f.gets
|
||||
t0 = Time.now
|
||||
|
@ -1473,10 +1472,11 @@ class TestProcess < Test::Unit::TestCase
|
|||
th.kill.join
|
||||
end
|
||||
t1 = Time.now
|
||||
diff = t1 - t0
|
||||
assert_operator(diff, :<, sec,
|
||||
->{"#{bug11340}: #{diff} seconds to interrupt Process.wait"})
|
||||
f.puts
|
||||
end
|
||||
assert_operator(t1 - t0, :<, 3,
|
||||
->{"#{bug11340}: #{t1-t0} seconds to interrupt Process.wait"})
|
||||
end
|
||||
|
||||
def test_abort
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue