summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-03-09 13:49:07 +0000
committernagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-03-09 13:49:07 +0000
commitfa4e355e578afdd71bf45d51b3d6802d687287fd (patch)
treedbb811814b5772b65c7f3972ca472ad708a0842b
parent79b2fb05591c87174fc1c76342b0836b91c6b415 (diff)
merge revision(s) 39417: [Backport #7904]
test_process.rb: fix test * test/ruby/test_process.rb (assert_fail_too_long_path): get rid of syntax error on sh, increase command line size until it exceeds the limit. [Bug #7904] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@39665 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--test/ruby/test_process.rb22
-rw-r--r--version.h2
2 files changed, 17 insertions, 7 deletions
diff --git a/test/ruby/test_process.rb b/test/ruby/test_process.rb
index 9ee7bdfd93..a70dca692e 100644
--- a/test/ruby/test_process.rb
+++ b/test/ruby/test_process.rb
@@ -1380,24 +1380,34 @@ class TestProcess < Test::Unit::TestCase
def test_spawn_too_long_path
bug4314 = '[ruby-core:34842]'
- assert_fail_too_long_path("a", bug4314)
+ assert_fail_too_long_path(%w"echo", bug4314)
end
def test_aspawn_too_long_path
bug4315 = '[ruby-core:34833]'
- assert_fail_too_long_path("a|", bug4315)
+ assert_fail_too_long_path(%w"echo |", bug4315)
end
- def assert_fail_too_long_path(cmd, mesg)
- size = 1_000_000 / cmd.size
+ def assert_fail_too_long_path((cmd, sep), mesg)
+ sep ||= ""
+ min = 1_000 / (cmd.size + sep.size)
+ cmds = Array.new(min, cmd)
exs = [Errno::ENOENT]
exs << Errno::E2BIG if defined?(Errno::E2BIG)
EnvUtil.suppress_warning do
assert_raise(*exs, mesg) do
begin
- Process.spawn(cmd * size)
+ loop do
+ Process.spawn(cmds.join(sep), [STDOUT, STDERR]=>:close)
+ min = [cmds.size, min].max
+ cmds *= 100
+ end
rescue NoMemoryError
- raise if (size /= 2) < 250
+ size = cmds.size
+ raise if min >= size - 1
+ min = [min, size /= 2].max
+ cmds[size..-1] = []
+ raise if size < 250
retry
end
end
diff --git a/version.h b/version.h
index 9d321bb91c..351c7d6cd1 100644
--- a/version.h
+++ b/version.h
@@ -1,6 +1,6 @@
#define RUBY_VERSION "2.0.0"
#define RUBY_RELEASE_DATE "2013-03-09"
-#define RUBY_PATCHLEVEL 34
+#define RUBY_PATCHLEVEL 35
#define RUBY_RELEASE_YEAR 2013
#define RUBY_RELEASE_MONTH 3