mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
349f6a3275
These will help us track down test failures more easily (on FreeBSD 11.2) git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@66335 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
53 lines
1.3 KiB
Ruby
53 lines
1.3 KiB
Ruby
# frozen_string_literal: false
|
|
require_relative 'helper'
|
|
|
|
module DTrace
|
|
class TestHashCreate < TestCase
|
|
def test_hash_new
|
|
trap_probe(probe, 'Hash.new') { |_,rbfile,saw|
|
|
saw = saw.map(&:split).find_all { |num, file, line|
|
|
file == rbfile && num == '0'
|
|
}
|
|
assert_operator saw.length, :>, 0
|
|
}
|
|
end
|
|
|
|
def test_hash_lit
|
|
trap_probe(probe, '{}') { |_,rbfile,saw|
|
|
saw = saw.map(&:split).find_all { |num, file, line|
|
|
file == rbfile && num == '0'
|
|
}
|
|
assert_operator saw.length, :>, 0
|
|
}
|
|
end
|
|
|
|
def test_hash_lit_elements
|
|
trap_probe(probe, '{ :foo => :bar }') { |_,rbfile,orig|
|
|
saw = orig.map(&:split).find_all { |num, file, line|
|
|
file == rbfile && num == '2'
|
|
}
|
|
assert_operator saw.length, :>, 0, orig
|
|
}
|
|
end
|
|
|
|
def test_hash_lit_elements_string
|
|
trap_probe(probe, '{ :foo => :bar, :bar => "baz" }') { |_,rbfile,saw|
|
|
saw = saw.map(&:split).find_all { |num, file, line|
|
|
file == rbfile && num == '4'
|
|
}
|
|
assert_operator saw.length, :>, 0
|
|
}
|
|
end
|
|
|
|
private
|
|
def probe
|
|
<<-eoprobe
|
|
ruby$target:::hash-create
|
|
/arg1/
|
|
{
|
|
printf("%d %s %d\\n", arg0, copyinstr(arg1), arg2);
|
|
}
|
|
eoprobe
|
|
end
|
|
end
|
|
end if defined?(DTrace::TestCase)
|