ruby-prof 1.7.1 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (134) hide show
  1. checksums.yaml +4 -4
  2. data/{CHANGES → CHANGELOG.md} +118 -176
  3. data/README.md +5 -5
  4. data/bin/ruby-prof +1 -4
  5. data/docs/advanced-usage.md +132 -0
  6. data/docs/alternatives.md +98 -0
  7. data/docs/architecture.md +122 -0
  8. data/docs/best-practices.md +27 -0
  9. data/docs/getting-started.md +130 -0
  10. data/docs/history.md +11 -0
  11. data/docs/index.md +45 -0
  12. data/docs/profiling-rails.md +64 -0
  13. data/docs/public/examples/example.rb +33 -0
  14. data/docs/public/examples/generate_reports.rb +92 -0
  15. data/docs/public/examples/reports/call_info.txt +27 -0
  16. data/docs/public/examples/reports/call_stack.html +835 -0
  17. data/docs/public/examples/reports/callgrind.out +150 -0
  18. data/docs/public/examples/reports/flame_graph.html +408 -0
  19. data/docs/public/examples/reports/flat.txt +45 -0
  20. data/docs/public/examples/reports/graph.dot +129 -0
  21. data/docs/public/examples/reports/graph.html +1319 -0
  22. data/docs/public/examples/reports/graph.txt +100 -0
  23. data/docs/public/examples/reports/graphviz_viewer.html +1 -0
  24. data/docs/public/images/call_stack.png +0 -0
  25. data/docs/public/images/class_diagram.png +0 -0
  26. data/docs/public/images/dot_printer.png +0 -0
  27. data/docs/public/images/flame_graph.png +0 -0
  28. data/docs/public/images/flat.png +0 -0
  29. data/docs/public/images/graph.png +0 -0
  30. data/docs/public/images/graph_html.png +0 -0
  31. data/docs/public/images/ruby-prof-logo.svg +1 -0
  32. data/docs/reports.md +150 -0
  33. data/docs/stylesheets/extra.css +80 -0
  34. data/ext/ruby_prof/extconf.rb +23 -22
  35. data/ext/ruby_prof/rp_allocation.c +0 -15
  36. data/ext/ruby_prof/rp_allocation.h +29 -33
  37. data/ext/ruby_prof/rp_call_tree.c +3 -0
  38. data/ext/ruby_prof/rp_call_tree.h +1 -4
  39. data/ext/ruby_prof/rp_call_trees.c +296 -296
  40. data/ext/ruby_prof/rp_call_trees.h +25 -28
  41. data/ext/ruby_prof/rp_measure_allocations.c +47 -47
  42. data/ext/ruby_prof/rp_measure_process_time.c +64 -66
  43. data/ext/ruby_prof/rp_measure_wall_time.c +52 -64
  44. data/ext/ruby_prof/rp_measurement.c +0 -5
  45. data/ext/ruby_prof/rp_measurement.h +49 -53
  46. data/ext/ruby_prof/rp_method.c +554 -551
  47. data/ext/ruby_prof/rp_method.h +1 -4
  48. data/ext/ruby_prof/rp_profile.c +1 -1
  49. data/ext/ruby_prof/rp_profile.h +1 -5
  50. data/ext/ruby_prof/rp_stack.c +212 -212
  51. data/ext/ruby_prof/rp_stack.h +50 -53
  52. data/ext/ruby_prof/rp_thread.h +1 -4
  53. data/ext/ruby_prof/ruby_prof.c +50 -50
  54. data/ext/ruby_prof/ruby_prof.h +4 -6
  55. data/ext/ruby_prof/vc/ruby_prof.vcxproj +7 -8
  56. data/lib/ruby-prof/assets/call_stack_printer.html.erb +746 -711
  57. data/lib/ruby-prof/assets/flame_graph_printer.html.erb +412 -0
  58. data/lib/ruby-prof/assets/graph_printer.html.erb +355 -355
  59. data/lib/ruby-prof/call_tree.rb +57 -57
  60. data/lib/ruby-prof/call_tree_visitor.rb +36 -36
  61. data/lib/ruby-prof/exclude_common_methods.rb +204 -204
  62. data/lib/ruby-prof/measurement.rb +17 -17
  63. data/lib/ruby-prof/printers/abstract_printer.rb +142 -138
  64. data/lib/ruby-prof/printers/call_info_printer.rb +53 -53
  65. data/lib/ruby-prof/printers/call_stack_printer.rb +168 -180
  66. data/lib/ruby-prof/printers/call_tree_printer.rb +132 -145
  67. data/lib/ruby-prof/printers/dot_printer.rb +177 -132
  68. data/lib/ruby-prof/printers/flame_graph_printer.rb +79 -0
  69. data/lib/ruby-prof/printers/flat_printer.rb +52 -52
  70. data/lib/ruby-prof/printers/graph_html_printer.rb +62 -63
  71. data/lib/ruby-prof/printers/graph_printer.rb +112 -113
  72. data/lib/ruby-prof/printers/multi_printer.rb +134 -127
  73. data/lib/ruby-prof/profile.rb +13 -0
  74. data/lib/ruby-prof/rack.rb +114 -105
  75. data/lib/ruby-prof/task.rb +147 -147
  76. data/lib/ruby-prof/thread.rb +20 -20
  77. data/lib/ruby-prof/version.rb +3 -3
  78. data/lib/ruby-prof.rb +50 -52
  79. data/lib/unprof.rb +10 -10
  80. data/ruby-prof.gemspec +66 -65
  81. data/test/abstract_printer_test.rb +25 -27
  82. data/test/alias_test.rb +203 -117
  83. data/test/call_tree_builder.rb +126 -126
  84. data/test/call_tree_visitor_test.rb +27 -27
  85. data/test/call_trees_test.rb +66 -66
  86. data/test/duplicate_names_test.rb +32 -32
  87. data/test/dynamic_method_test.rb +50 -62
  88. data/test/enumerable_test.rb +23 -21
  89. data/test/exceptions_test.rb +24 -24
  90. data/test/exclude_methods_test.rb +363 -257
  91. data/test/exclude_threads_test.rb +48 -48
  92. data/test/fiber_test.rb +195 -195
  93. data/test/gc_test.rb +104 -102
  94. data/test/inverse_call_tree_test.rb +174 -174
  95. data/test/line_number_test.rb +563 -289
  96. data/test/marshal_test.rb +144 -145
  97. data/test/measure_allocations.rb +26 -26
  98. data/test/measure_allocations_test.rb +1511 -1081
  99. data/test/measure_process_time_test.rb +3286 -2477
  100. data/test/measure_times.rb +56 -56
  101. data/test/measure_wall_time_test.rb +773 -568
  102. data/test/measurement_test.rb +82 -82
  103. data/test/merge_test.rb +146 -146
  104. data/test/method_info_test.rb +100 -95
  105. data/test/multi_printer_test.rb +52 -66
  106. data/test/no_method_class_test.rb +15 -15
  107. data/test/pause_resume_test.rb +171 -171
  108. data/test/prime.rb +54 -54
  109. data/test/prime_script.rb +5 -5
  110. data/test/printer_call_stack_test.rb +28 -27
  111. data/test/printer_call_tree_test.rb +30 -30
  112. data/test/printer_flame_graph_test.rb +82 -0
  113. data/test/printer_flat_test.rb +99 -99
  114. data/test/printer_graph_html_test.rb +62 -59
  115. data/test/printer_graph_test.rb +42 -40
  116. data/test/printers_test.rb +162 -135
  117. data/test/printing_recursive_graph_test.rb +81 -81
  118. data/test/profile_test.rb +101 -101
  119. data/test/rack_test.rb +103 -93
  120. data/test/recursive_test.rb +796 -622
  121. data/test/scheduler.rb +4 -0
  122. data/test/singleton_test.rb +39 -38
  123. data/test/stack_printer_test.rb +61 -61
  124. data/test/start_stop_test.rb +106 -106
  125. data/test/test_helper.rb +24 -20
  126. data/test/thread_test.rb +229 -231
  127. data/test/unique_call_path_test.rb +123 -136
  128. data/test/yarv_test.rb +56 -60
  129. metadata +68 -16
  130. data/ext/ruby_prof/rp_measure_memory.c +0 -46
  131. data/lib/ruby-prof/compatibility.rb +0 -113
  132. data/test/compatibility_test.rb +0 -49
  133. data/test/crash2.rb +0 -144
  134. data/test/measure_memory_test.rb +0 -1456
data/test/gc_test.rb CHANGED
@@ -1,102 +1,104 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
- Minitest::Test.i_suck_and_my_tests_are_order_dependent!
6
-
7
- class GcTest < TestCase
8
- def setup
9
- super
10
- GC.stress = true
11
- end
12
-
13
- def teardown
14
- GC.stress = false
15
- end
16
-
17
- def some_method
18
- Array.new(3 * 4)
19
- end
20
-
21
- def run_profile
22
- RubyProf::Profile.profile do
23
- self.some_method
24
- end
25
- end
26
-
27
- def test_hold_onto_thread
28
- threads = 5.times.reduce(Array.new) do |array, i|
29
- array.concat(run_profile.threads)
30
- array
31
- end
32
-
33
- GC.start
34
-
35
- threads.each do |thread|
36
- refute_nil(thread.id)
37
- end
38
- end
39
-
40
- def test_hold_onto_method
41
- methods = 5.times.reduce(Array.new) do |array, i|
42
- profile = run_profile
43
- array.concat(profile.threads.map(&:methods).flatten)
44
- array
45
- end
46
-
47
- GC.start
48
-
49
- methods.each do |method|
50
- refute_nil(method.method_name)
51
- end
52
- end
53
-
54
- def test_hold_onto_call_trees
55
- method_call_infos = 5.times.reduce(Array.new) do |array, i|
56
- profile = run_profile
57
- call_trees = profile.threads.map(&:methods).flatten.map(&:call_trees).flatten
58
- array.concat(call_trees)
59
- array
60
- end
61
-
62
- GC.start
63
-
64
- method_call_infos.each do |call_trees|
65
- refute_empty(call_trees.call_trees)
66
- end
67
- end
68
-
69
- def test_hold_onto_measurements
70
- # Run a profile
71
- profile = run_profile
72
-
73
- # Get measurement objects
74
- measurements = profile.threads.map(&:methods).flatten.map(&:measurement)
75
-
76
- # Free the profiles which frees the measurements
77
- profile = nil
78
-
79
- GC.start
80
-
81
- measurements.each_with_index do |measurement|
82
- error = assert_raises(RuntimeError) do
83
- measurement.total_time
84
- end
85
- assert_match(/RubyProf::Measurement instance has already been freed/, error.message)
86
- end
87
- assert(true)
88
- end
89
-
90
- def test_hold_onto_root_call_tree
91
- call_trees = 5.times.reduce(Array.new) do |array, i|
92
- array.concat(run_profile.threads.map(&:call_tree))
93
- array
94
- end
95
-
96
- GC.start
97
-
98
- call_trees.each do |call_tree|
99
- refute_nil(call_tree.source_file)
100
- end
101
- end
102
- end
1
+ #!/usr/bin/env ruby
2
+ # encoding: UTF-8
3
+
4
+ require File.expand_path('../test_helper', __FILE__)
5
+ Minitest::Test.i_suck_and_my_tests_are_order_dependent!
6
+
7
+ class GcTest < TestCase
8
+ def setup
9
+ super
10
+ GC.stress = true
11
+ end
12
+
13
+ def teardown
14
+ GC.stress = false
15
+ end
16
+
17
+ def some_method
18
+ Array.new(3 * 4)
19
+ end
20
+
21
+ def run_profile
22
+ RubyProf::Profile.profile do
23
+ self.some_method
24
+ end
25
+ end
26
+
27
+ def test_hold_onto_thread
28
+ threads = 5.times.reduce(Array.new) do |array, i|
29
+ array.concat(run_profile.threads)
30
+ array
31
+ end
32
+
33
+ GC.start
34
+
35
+ threads.each do |thread|
36
+ refute_nil(thread.id)
37
+ end
38
+ end
39
+
40
+ def test_hold_onto_method
41
+ methods = 5.times.reduce(Array.new) do |array, i|
42
+ profile = run_profile
43
+ array.concat(profile.threads.map(&:methods).flatten)
44
+ array
45
+ end
46
+
47
+ GC.start
48
+
49
+ methods.each do |method|
50
+ refute_nil(method.method_name)
51
+ end
52
+ end
53
+
54
+ def test_hold_onto_call_trees
55
+ method_call_infos = 5.times.reduce(Array.new) do |array, i|
56
+ profile = run_profile
57
+ call_trees = profile.threads.map(&:methods).flatten.map(&:call_trees).flatten
58
+ array.concat(call_trees)
59
+ array
60
+ end
61
+
62
+ GC.start
63
+
64
+ method_call_infos.each do |call_trees|
65
+ refute_empty(call_trees.call_trees)
66
+ end
67
+ end
68
+
69
+ unless windows?
70
+ def test_hold_onto_measurements
71
+ # Run a profile
72
+ profile = run_profile
73
+
74
+ # Get measurement objects
75
+ measurements = profile.threads.map(&:methods).flatten.map(&:measurement)
76
+
77
+ # Free the profiles which frees the measurements
78
+ profile = nil
79
+
80
+ GC.start
81
+
82
+ measurements.each_with_index do |measurement|
83
+ error = assert_raises(RuntimeError) do
84
+ measurement.total_time
85
+ end
86
+ assert_match(/RubyProf::Measurement instance has already been freed/, error.message)
87
+ end
88
+ assert(true)
89
+ end
90
+ end
91
+
92
+ def test_hold_onto_root_call_tree
93
+ call_trees = 5.times.reduce(Array.new) do |array, i|
94
+ array.concat(run_profile.threads.map(&:call_tree))
95
+ array
96
+ end
97
+
98
+ GC.start
99
+
100
+ call_trees.each do |call_tree|
101
+ refute_nil(call_tree.source_file)
102
+ end
103
+ end
104
+ end
@@ -1,174 +1,174 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
-
6
- class InverseCallTreeTest < TestCase
7
- def setup
8
- super
9
- @profile = RubyProf::Profile.new
10
- end
11
- INVERSE_DEPTH = 5
12
-
13
- INVERSE_DEPTH.times do |i|
14
- if i == 0
15
- define_method("method_#{i}") do
16
- sleep_amount = (i + 1) * 0.05
17
- @profile.start
18
- sleep(sleep_amount)
19
- end
20
- else
21
- define_method("method_#{i}") do
22
- method_name = "method_#{i-1}"
23
- sleep_amount = (i + 1) * 0.05
24
- self.send(method_name.to_sym)
25
- sleep(sleep_amount)
26
- end
27
- end
28
- end
29
-
30
- def test_inverse
31
- method_name = "method_#{INVERSE_DEPTH - 1}"
32
- self.send(method_name.to_sym)
33
- result = @profile.stop
34
-
35
- assert_equal(1, result.threads.count)
36
-
37
- thread = result.threads.first
38
- assert_in_delta(0.79, thread.total_time, 0.05)
39
-
40
- assert_equal(7, thread.methods.length)
41
- methods = thread.methods.sort.reverse
42
-
43
- # InverseCallTreeTest#test_inverse
44
- method = methods[0]
45
- assert_equal('InverseCallTreeTest#test_inverse', method.full_name)
46
- assert_equal(33, method.line)
47
-
48
- assert_equal(0, method.call_trees.callers.count)
49
-
50
- assert_equal(1, method.call_trees.callees.count)
51
- call_tree = method.call_trees.callees[0]
52
- assert_equal('InverseCallTreeTest#method_4', call_tree.target.full_name)
53
- assert_equal(25, call_tree.line)
54
-
55
- # InverseCallTreeTest#method_4
56
- method = methods[1]
57
- assert_equal('InverseCallTreeTest#method_4', method.full_name)
58
- assert_equal(25, method.line)
59
-
60
- assert_equal(1, method.call_trees.callers.count)
61
- call_tree = method.call_trees.callers[0]
62
- assert_equal('InverseCallTreeTest#test_inverse', call_tree.parent.target.full_name)
63
- assert_equal(25, call_tree.line)
64
-
65
- assert_equal(2, method.call_trees.callees.count)
66
- call_tree = method.call_trees.callees[0]
67
- assert_equal('InverseCallTreeTest#method_3', call_tree.target.full_name)
68
- assert_equal(25, call_tree.line)
69
-
70
- # Kernel#sleep
71
- method = methods[2]
72
- assert_equal('Kernel#sleep', method.full_name)
73
- assert_equal(0, method.line)
74
-
75
- assert_equal(5, method.call_trees.callers.count)
76
- call_tree = method.call_trees.callers[0]
77
- assert_equal('InverseCallTreeTest#method_0', call_tree.parent.target.full_name)
78
- assert_equal(18, call_tree.line)
79
-
80
- call_tree = method.call_trees.callers[1]
81
- assert_equal('InverseCallTreeTest#method_1', call_tree.parent.target.full_name)
82
- assert_equal(25, call_tree.line)
83
-
84
- call_tree = method.call_trees.callers[2]
85
- assert_equal('InverseCallTreeTest#method_2', call_tree.parent.target.full_name)
86
- assert_equal(25, call_tree.line)
87
- call_tree = method.call_trees.callers[3]
88
-
89
- assert_equal('InverseCallTreeTest#method_3', call_tree.parent.target.full_name)
90
- assert_equal(25, call_tree.line)
91
-
92
- call_tree = method.call_trees.callers[4]
93
- assert_equal('InverseCallTreeTest#method_4', call_tree.parent.target.full_name)
94
- assert_equal(25, call_tree.line)
95
-
96
- assert_equal(0, method.call_trees.callees.count)
97
-
98
- # InverseCallTreeTest#method_3
99
- method = methods[3]
100
- assert_equal('InverseCallTreeTest#method_3', method.full_name)
101
- assert_equal(25, method.line)
102
-
103
- assert_equal(1, method.call_trees.callers.count)
104
- call_tree = method.call_trees.callers[0]
105
- assert_equal('InverseCallTreeTest#method_4', call_tree.parent.target.full_name)
106
- assert_equal(25, call_tree.line)
107
-
108
- assert_equal(2, method.call_trees.callees.count)
109
- call_tree = method.call_trees.callees[0]
110
- assert_equal('InverseCallTreeTest#method_2', call_tree.target.full_name)
111
- assert_equal(25, call_tree.line)
112
-
113
- call_tree = method.call_trees.callees[1]
114
- assert_equal('Kernel#sleep', call_tree.target.full_name)
115
- assert_equal(25, call_tree.line)
116
-
117
- # InverseCallTreeTest#method_2
118
- method = methods[4]
119
- assert_equal('InverseCallTreeTest#method_2', method.full_name)
120
- assert_equal(25, method.line)
121
-
122
- assert_equal(1, method.call_trees.callers.count)
123
- call_tree = method.call_trees.callers[0]
124
- assert_equal('InverseCallTreeTest#method_3', call_tree.parent.target.full_name)
125
- assert_equal(25, call_tree.line)
126
-
127
- assert_equal(2, method.call_trees.callees.count)
128
- call_tree = method.call_trees.callees[0]
129
- assert_equal('InverseCallTreeTest#method_1', call_tree.target.full_name)
130
- assert_equal(25, call_tree.line)
131
-
132
- call_tree = method.call_trees.callees[1]
133
- assert_equal('Kernel#sleep', call_tree.target.full_name)
134
- assert_equal(25, call_tree.line)
135
-
136
- call_tree = method.call_trees.callees[1]
137
- assert_equal('Kernel#sleep', call_tree.target.full_name)
138
- assert_equal(25, call_tree.line)
139
-
140
- # InverseCallTreeTest#method_1
141
- method = methods[5]
142
- assert_equal('InverseCallTreeTest#method_1', method.full_name)
143
- assert_equal(25, method.line)
144
-
145
- assert_equal(1, method.call_trees.callers.count)
146
- call_tree = method.call_trees.callers[0]
147
- assert_equal('InverseCallTreeTest#method_2', call_tree.parent.target.full_name)
148
- assert_equal(25, call_tree.line)
149
-
150
- assert_equal(2, method.call_trees.callees.count)
151
- call_tree = method.call_trees.callees[0]
152
- assert_equal('InverseCallTreeTest#method_0', call_tree.target.full_name)
153
- assert_equal(18, call_tree.line)
154
-
155
- call_tree = method.call_trees.callees[1]
156
- assert_equal('Kernel#sleep', call_tree.target.full_name)
157
- assert_equal(25, call_tree.line)
158
-
159
- # InverseCallTreeTest#method_0
160
- method = methods[6]
161
- assert_equal('InverseCallTreeTest#method_0', method.full_name)
162
- assert_equal(18, method.line)
163
-
164
- assert_equal(1, method.call_trees.callers.count)
165
- call_tree = method.call_trees.callers[0]
166
- assert_equal('InverseCallTreeTest#method_1', call_tree.parent.target.full_name)
167
- assert_equal(18, call_tree.line)
168
-
169
- assert_equal(1, method.call_trees.callees.count)
170
- call_tree = method.call_trees.callees[0]
171
- assert_equal('Kernel#sleep', call_tree.target.full_name)
172
- assert_equal(18, call_tree.line)
173
- end
174
- end
1
+ #!/usr/bin/env ruby
2
+ # encoding: UTF-8
3
+
4
+ require File.expand_path('../test_helper', __FILE__)
5
+
6
+ class InverseCallTreeTest < TestCase
7
+ def setup
8
+ super
9
+ @profile = RubyProf::Profile.new
10
+ end
11
+ INVERSE_DEPTH = 5
12
+
13
+ INVERSE_DEPTH.times do |i|
14
+ if i == 0
15
+ define_method("method_#{i}") do
16
+ sleep_amount = (i + 1) * 0.05
17
+ @profile.start
18
+ sleep(sleep_amount)
19
+ end
20
+ else
21
+ define_method("method_#{i}") do
22
+ method_name = "method_#{i-1}"
23
+ sleep_amount = (i + 1) * 0.05
24
+ self.send(method_name.to_sym)
25
+ sleep(sleep_amount)
26
+ end
27
+ end
28
+ end
29
+
30
+ def test_inverse
31
+ method_name = "method_#{INVERSE_DEPTH - 1}"
32
+ self.send(method_name.to_sym)
33
+ result = @profile.stop
34
+
35
+ assert_equal(1, result.threads.count)
36
+
37
+ thread = result.threads.first
38
+ assert_in_delta(0.79, thread.total_time, 0.1 * delta_multiplier)
39
+
40
+ assert_equal(7, thread.methods.length)
41
+ methods = thread.methods.sort.reverse
42
+
43
+ # InverseCallTreeTest#test_inverse
44
+ method = methods[0]
45
+ assert_equal('InverseCallTreeTest#test_inverse', method.full_name)
46
+ assert_equal(33, method.line)
47
+
48
+ assert_equal(0, method.call_trees.callers.count)
49
+
50
+ assert_equal(1, method.call_trees.callees.count)
51
+ call_tree = method.call_trees.callees[0]
52
+ assert_equal('InverseCallTreeTest#method_4', call_tree.target.full_name)
53
+ assert_equal(25, call_tree.line)
54
+
55
+ # InverseCallTreeTest#method_4
56
+ method = methods[1]
57
+ assert_equal('InverseCallTreeTest#method_4', method.full_name)
58
+ assert_equal(25, method.line)
59
+
60
+ assert_equal(1, method.call_trees.callers.count)
61
+ call_tree = method.call_trees.callers[0]
62
+ assert_equal('InverseCallTreeTest#test_inverse', call_tree.parent.target.full_name)
63
+ assert_equal(25, call_tree.line)
64
+
65
+ assert_equal(2, method.call_trees.callees.count)
66
+ call_tree = method.call_trees.callees[0]
67
+ assert_equal('InverseCallTreeTest#method_3', call_tree.target.full_name)
68
+ assert_equal(25, call_tree.line)
69
+
70
+ # Kernel#sleep
71
+ method = methods[2]
72
+ assert_equal('Kernel#sleep', method.full_name)
73
+ assert_equal(0, method.line)
74
+
75
+ assert_equal(5, method.call_trees.callers.count)
76
+ call_tree = method.call_trees.callers[0]
77
+ assert_equal('InverseCallTreeTest#method_0', call_tree.parent.target.full_name)
78
+ assert_equal(18, call_tree.line)
79
+
80
+ call_tree = method.call_trees.callers[1]
81
+ assert_equal('InverseCallTreeTest#method_1', call_tree.parent.target.full_name)
82
+ assert_equal(25, call_tree.line)
83
+
84
+ call_tree = method.call_trees.callers[2]
85
+ assert_equal('InverseCallTreeTest#method_2', call_tree.parent.target.full_name)
86
+ assert_equal(25, call_tree.line)
87
+ call_tree = method.call_trees.callers[3]
88
+
89
+ assert_equal('InverseCallTreeTest#method_3', call_tree.parent.target.full_name)
90
+ assert_equal(25, call_tree.line)
91
+
92
+ call_tree = method.call_trees.callers[4]
93
+ assert_equal('InverseCallTreeTest#method_4', call_tree.parent.target.full_name)
94
+ assert_equal(25, call_tree.line)
95
+
96
+ assert_equal(0, method.call_trees.callees.count)
97
+
98
+ # InverseCallTreeTest#method_3
99
+ method = methods[3]
100
+ assert_equal('InverseCallTreeTest#method_3', method.full_name)
101
+ assert_equal(25, method.line)
102
+
103
+ assert_equal(1, method.call_trees.callers.count)
104
+ call_tree = method.call_trees.callers[0]
105
+ assert_equal('InverseCallTreeTest#method_4', call_tree.parent.target.full_name)
106
+ assert_equal(25, call_tree.line)
107
+
108
+ assert_equal(2, method.call_trees.callees.count)
109
+ call_tree = method.call_trees.callees[0]
110
+ assert_equal('InverseCallTreeTest#method_2', call_tree.target.full_name)
111
+ assert_equal(25, call_tree.line)
112
+
113
+ call_tree = method.call_trees.callees[1]
114
+ assert_equal('Kernel#sleep', call_tree.target.full_name)
115
+ assert_equal(25, call_tree.line)
116
+
117
+ # InverseCallTreeTest#method_2
118
+ method = methods[4]
119
+ assert_equal('InverseCallTreeTest#method_2', method.full_name)
120
+ assert_equal(25, method.line)
121
+
122
+ assert_equal(1, method.call_trees.callers.count)
123
+ call_tree = method.call_trees.callers[0]
124
+ assert_equal('InverseCallTreeTest#method_3', call_tree.parent.target.full_name)
125
+ assert_equal(25, call_tree.line)
126
+
127
+ assert_equal(2, method.call_trees.callees.count)
128
+ call_tree = method.call_trees.callees[0]
129
+ assert_equal('InverseCallTreeTest#method_1', call_tree.target.full_name)
130
+ assert_equal(25, call_tree.line)
131
+
132
+ call_tree = method.call_trees.callees[1]
133
+ assert_equal('Kernel#sleep', call_tree.target.full_name)
134
+ assert_equal(25, call_tree.line)
135
+
136
+ call_tree = method.call_trees.callees[1]
137
+ assert_equal('Kernel#sleep', call_tree.target.full_name)
138
+ assert_equal(25, call_tree.line)
139
+
140
+ # InverseCallTreeTest#method_1
141
+ method = methods[5]
142
+ assert_equal('InverseCallTreeTest#method_1', method.full_name)
143
+ assert_equal(25, method.line)
144
+
145
+ assert_equal(1, method.call_trees.callers.count)
146
+ call_tree = method.call_trees.callers[0]
147
+ assert_equal('InverseCallTreeTest#method_2', call_tree.parent.target.full_name)
148
+ assert_equal(25, call_tree.line)
149
+
150
+ assert_equal(2, method.call_trees.callees.count)
151
+ call_tree = method.call_trees.callees[0]
152
+ assert_equal('InverseCallTreeTest#method_0', call_tree.target.full_name)
153
+ assert_equal(18, call_tree.line)
154
+
155
+ call_tree = method.call_trees.callees[1]
156
+ assert_equal('Kernel#sleep', call_tree.target.full_name)
157
+ assert_equal(25, call_tree.line)
158
+
159
+ # InverseCallTreeTest#method_0
160
+ method = methods[6]
161
+ assert_equal('InverseCallTreeTest#method_0', method.full_name)
162
+ assert_equal(18, method.line)
163
+
164
+ assert_equal(1, method.call_trees.callers.count)
165
+ call_tree = method.call_trees.callers[0]
166
+ assert_equal('InverseCallTreeTest#method_1', call_tree.parent.target.full_name)
167
+ assert_equal(18, call_tree.line)
168
+
169
+ assert_equal(1, method.call_trees.callees.count)
170
+ call_tree = method.call_trees.callees[0]
171
+ assert_equal('Kernel#sleep', call_tree.target.full_name)
172
+ assert_equal(18, call_tree.line)
173
+ end
174
+ end