1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
ruby--ruby/test/dtrace/test_method_cache.rb
normal ca9cf0e076 test/dtrace/test_method_cache.rb: avoid spewing too much
Don't output method cache clearing at startup since
it causes dtrace to drop output and break the test.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@63579 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2018-06-05 21:19:40 +00:00

29 lines
726 B
Ruby

# frozen_string_literal: false
require_relative 'helper'
module DTrace
class TestMethodCacheClear < TestCase
def test_method_cache_clear
trap_probe(probe, <<-code) do |_,rbfile,lines|
class String; end
class String; def abc() end end
class Object; def abc() end end
code
assert_not_include lines, "String #{rbfile} 1\n"
assert_include lines, "String #{rbfile} 2\n"
assert_include lines, "global #{rbfile} 3\n"
end
end
private
def probe
<<-eoprobe
ruby$target:::method-cache-clear
/arg1 && arg2/
{
printf("%s %s %d\\n", copyinstr(arg0), copyinstr(arg1), arg2);
}
eoprobe
end
end
end if defined?(DTrace::TestCase)