summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--test/ruby/envutil.rb17
-rw-r--r--test/ruby/memory_status.rb17
-rw-r--r--version.h2
3 files changed, 28 insertions, 8 deletions
diff --git a/test/ruby/envutil.rb b/test/ruby/envutil.rb
index 030292fefe..5e71028ce4 100644
--- a/test/ruby/envutil.rb
+++ b/test/ruby/envutil.rb
@@ -341,6 +341,7 @@ eom
end
def assert_no_memory_leak(args, prepare, code, message=nil, limit: 1.5)
+ require_relative 'memory_status'
token = "\e[7;1m#{$$.to_s}:#{Time.now.strftime('%s.%L')}:#{rand(0x10000).to_s(16)}:\e[m"
token_dump = token.dump
token_re = Regexp.quote(token)
@@ -351,16 +352,22 @@ eom
"-v", "-",
]
cmd = [
- 'END {STDERR.puts '"#{token_dump}"'"FINAL=#{Memory::Status.new.size}"}',
+ 'END {STDERR.puts '"#{token_dump}"'"FINAL=#{Memory::Status.new}"}',
prepare,
- 'STDERR.puts('"#{token_dump}"'"START=#{$initial_size = Memory::Status.new.size}")',
+ 'STDERR.puts('"#{token_dump}"'"START=#{$initial_size = Memory::Status.new}")',
code,
+ 'GC.start',
].join("\n")
_, err, status = EnvUtil.invoke_ruby(args, cmd, true, true)
- before = err.sub!(/^#{token_re}START=(\d+)\n/, '') && $1.to_i
- after = err.sub!(/^#{token_re}FINAL=(\d+)\n/, '') && $1.to_i
+ before = err.sub!(/^#{token_re}START=(\{.*\})\n/, '') && Memory::Status.parse($1)
+ after = err.sub!(/^#{token_re}FINAL=(\{.*\})\n/, '') && Memory::Status.parse($1)
assert_equal([true, ""], [status.success?, err], message)
- assert_operator(after.fdiv(before), :<, limit, message)
+ ([:size, :rss] & after.members).each do |n|
+ b = before[n]
+ a = after[n]
+ next unless a > 0 and b > 0
+ assert_operator(a.fdiv(b), :<, limit, message(message) {"#{n}: #{b} => #{a}"})
+ end
end
def assert_is_minus_zero(f)
diff --git a/test/ruby/memory_status.rb b/test/ruby/memory_status.rb
index cb2e9e094c..bfbfbd6e88 100644
--- a/test/ruby/memory_status.rb
+++ b/test/ruby/memory_status.rb
@@ -1,5 +1,3 @@
-require_relative "envutil"
-
module Memory
keys = []
vals = []
@@ -110,5 +108,20 @@ module Memory
def initialize
_update
end
+
+ def to_s
+ status = each_pair.map {|n,v|
+ "#{n}:#{v}"
+ }
+ "{#{status.join(",")}}"
+ end
+
+ def self.parse(str)
+ status = allocate
+ str.scan(/(?:\A\{|\G,)(#{members.join('|')}):(\d+)(?=,|\}\z)/) do
+ status[$1] = $2.to_i
+ end
+ status
+ end
end
end
diff --git a/version.h b/version.h
index 16406c85ee..a14405c2e3 100644
--- a/version.h
+++ b/version.h
@@ -1,6 +1,6 @@
#define RUBY_VERSION "2.0.0"
#define RUBY_RELEASE_DATE "2014-03-20"
-#define RUBY_PATCHLEVEL 459
+#define RUBY_PATCHLEVEL 460
#define RUBY_RELEASE_YEAR 2014
#define RUBY_RELEASE_MONTH 3