Sha256: 88f406de7766526fc0116a187bc437f3feb662606fe9a2cabace5448ebf2d8c2

Contents?: true

Size: 839 Bytes

Versions: 5

Compression:

Stored size: 839 Bytes

Contents

#!/usr/bin/env ruby
# encoding: UTF-8

require File.expand_path('../test_helper', __FILE__)

class CallInfoVisitorTest < Test::Unit::TestCase
  def setup
    # Need to use wall time for this test due to the sleep calls
    RubyProf::measure_mode = RubyProf::WALL_TIME
  end

  def test_visit
    result = RubyProf.profile do
      RubyProf::C1.hello
    end

    visitor = RubyProf::CallInfoVisitor.new(result.threads.first)

    method_names = Array.new

    visitor.visit do |call_info, event|
      method_names << call_info.target.full_name if event == :enter
    end

    assert_equal(3, method_names.length)
    assert_equal("CallInfoVisitorTest#test_visit", method_names[0])
    assert_equal("<Class::RubyProf::C1>#hello", method_names[1])
    assert_equal("Kernel#sleep", method_names[2])
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
ruby-prof-0.13.1 test/call_info_visitor_test.rb
ruby-prof-0.13.0 test/call_info_visitor_test.rb
ruby-prof-0.12.2 test/call_info_visitor_test.rb
ruby-prof-0.12.1-x86-mingw32 test/call_info_visitor_test.rb
ruby-prof-0.12.1 test/call_info_visitor_test.rb