File: issue137_test.rb

package info (click to toggle)
ruby-prof 0.17.0%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 1,656 kB
  • sloc: ruby: 5,043; ansic: 2,175; makefile: 6
file content (63 lines) | stat: -rwxr-xr-x 1,491 bytes parent folder | download | duplicates (2)
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
#!/usr/bin/env ruby
# encoding: UTF-8

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

# issue 137 is about correctly attributing time of recursive children

class RecursiveChildrenTest < TestCase
  class SlowClass
    def time_sink
      1234567890 ** 100 == 0
    end
  end

  class SlowSearcher
    def do_find(slow_objects)
      slow_objects.find(&:time_sink)
    end
  end

  class MainClass
    def self.main_method
      slow_objects = [SlowClass.new] * 100_000
      slow_searcher = SlowSearcher.new
      slow_searcher.do_find(slow_objects)
    end
  end

  include PrinterTestHelper

  def setup
    # Need to use wall time for this test due to the sleep calls
    RubyProf::measure_mode = RubyProf::WALL_TIME
  end

  def test_simple
    result = RubyProf.profile do
      # make array each recursive
      [1].each do
        MainClass.main_method
      end
    end

    # methods = result.threads.first.methods.sort.reverse

    printer = RubyProf::GraphPrinter.new(result)

    buffer = ''
    printer.print(StringIO.new(buffer))

    puts buffer if ENV['SHOW_RUBY_PROF_PRINTER_OUTPUT'] == "1"

    parsed_output = MetricsArray.parse(buffer)

    assert( enum_find  = parsed_output.metrics_for("Enumerable#find") )
    assert( array_each = enum_find.child("Array#each") )

    assert_operator enum_find.metrics.total, :>=, array_each.total
    assert_operator enum_find.metrics.total, :>, 0
    assert_in_delta enum_find.metrics.total, array_each.total, 0.02
  end

end