summaryrefslogtreecommitdiff
path: root/test/dtrace/test_raise.rb
blob: 48fdbf14d1eaa817a024f2dc7cb5de3141424d49 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
require_relative 'helper'

module DTrace
  class TestRaise < TestCase
    def test_raise
      probe = <<-eoprobe
ruby$target:::raise
{
  printf("%s %s %d\\n", copyinstr(arg0), copyinstr(arg1), arg2);
}
      eoprobe
      trap_probe(probe, program) { |dpath, rbpath, saw|
	saw = saw.map(&:split).find_all { |_, source_file, _|
	  source_file == rbpath
	}
	assert_equal 10, saw.length
	saw.each do |klass, _, source_line|
	  assert_equal 'RuntimeError', klass
	  assert_equal '1', source_line
	end
      }
    end

    private
    def program
      '10.times { raise rescue nil }'
    end
  end
end if defined?(DTrace::TestCase)