Sha256: 4f2dfef2114c9d398147a2b9024f498a771b35c864e543a91b326ffa8426fb92

Contents?: true

Size: 1.59 KB

Versions: 23

Compression:

Stored size: 1.59 KB

Contents

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

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

# Test data
#     A
#    / \
#   B   C
#        \
#         B

class MSTPT
  def a
    100.times{b}
    300.times{c}
    c;c;c
  end

  def b
    sleep 0
  end

  def c
    5.times{b}
  end
end

class MultiPrinterTest < 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_refuses_io_objects
    # we don't need a real profile for this test
    p = RubyProf::MultiPrinter.new nil
    begin
      p.print(STDOUT)
      flunk "should have raised an ArgumentError"
    rescue ArgumentError => e
      assert_match(/IO/, e.to_s)
    end
  end

  def test_refuses_non_hashes
    # we don't need a real profile for this test
    p = RubyProf::MultiPrinter.new nil
    begin
      p.print([])
      flunk "should have raised an ArgumentError"
    rescue ArgumentError => e
      assert_match(/hash/, e.to_s)
    end
  end

  private

  def print(result)
    test = caller.first =~ /in `(.*)'/ ? $1 : "test"
    path = Dir.tmpdir
    profile = "ruby_prof_#{test}"
    printer = RubyProf::MultiPrinter.new(result)
    printer.print(:path => path, :profile => profile,
                  :threshold => 0, :min_percent => 0, :title => "ruby_prof #{test}")
    if RUBY_PLATFORM =~ /darwin/ && ENV['SHOW_RUBY_PROF_PRINTER_OUTPUT']=="1"
      system("open '#{printer.stack_profile}'")
    end
    [File.read(printer.stack_profile), File.read(printer.graph_profile)]
  end
end

Version data entries

23 entries across 23 versions & 1 rubygems

Version Path
ruby-prof-1.5.0-x64-mingw-ucrt test/multi_printer_test.rb
ruby-prof-1.5.0 test/multi_printer_test.rb
ruby-prof-1.4.5-x64-mingw-ucrt test/multi_printer_test.rb
ruby-prof-1.4.5 test/multi_printer_test.rb
ruby-prof-1.4.4-x64-mingw-ucrt test/multi_printer_test.rb
ruby-prof-1.4.4 test/multi_printer_test.rb
ruby-prof-1.4.3-x64-mingw32 test/multi_printer_test.rb
ruby-prof-1.4.3 test/multi_printer_test.rb
ruby-prof-1.4.2-x64-mingw32 test/multi_printer_test.rb
ruby-prof-1.4.2 test/multi_printer_test.rb
ruby-prof-1.4.1-x64-mingw32 test/multi_printer_test.rb
ruby-prof-1.4.1 test/multi_printer_test.rb
ruby-prof-1.4.0-x64-mingw32 test/multi_printer_test.rb
ruby-prof-1.4.0 test/multi_printer_test.rb
ruby-prof-1.3.2 test/multi_printer_test.rb
ruby-prof-1.3.1-x64-mingw32 test/multi_printer_test.rb
ruby-prof-1.3.1 test/multi_printer_test.rb
ruby-prof-1.3.0-x64-mingw32 test/multi_printer_test.rb
ruby-prof-1.3.0 test/multi_printer_test.rb
ruby-prof-1.2.0 test/multi_printer_test.rb