ruby-prof 0.16.2 → 1.1.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 (203) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGES +532 -467
  3. data/LICENSE +24 -24
  4. data/README.rdoc +5 -454
  5. data/Rakefile +110 -113
  6. data/bin/ruby-prof +380 -340
  7. data/bin/ruby-prof-check-trace +45 -45
  8. data/ext/ruby_prof/extconf.rb +36 -64
  9. data/ext/ruby_prof/rp_allocation.c +279 -0
  10. data/ext/ruby_prof/rp_allocation.h +31 -0
  11. data/ext/ruby_prof/rp_call_info.c +271 -407
  12. data/ext/ruby_prof/rp_call_info.h +35 -48
  13. data/ext/ruby_prof/rp_measure_allocations.c +52 -76
  14. data/ext/ruby_prof/rp_measure_memory.c +42 -77
  15. data/ext/ruby_prof/rp_measure_process_time.c +67 -71
  16. data/ext/ruby_prof/rp_measure_wall_time.c +62 -45
  17. data/ext/ruby_prof/rp_measurement.c +230 -0
  18. data/ext/ruby_prof/rp_measurement.h +50 -0
  19. data/ext/ruby_prof/rp_method.c +630 -411
  20. data/ext/ruby_prof/rp_method.h +70 -52
  21. data/ext/ruby_prof/rp_profile.c +895 -0
  22. data/ext/ruby_prof/rp_profile.h +37 -0
  23. data/ext/ruby_prof/rp_stack.c +196 -128
  24. data/ext/ruby_prof/rp_stack.h +56 -51
  25. data/ext/ruby_prof/rp_thread.c +337 -273
  26. data/ext/ruby_prof/rp_thread.h +36 -27
  27. data/ext/ruby_prof/ruby_prof.c +48 -671
  28. data/ext/ruby_prof/ruby_prof.h +17 -56
  29. data/ext/ruby_prof/vc/ruby_prof.sln +20 -21
  30. data/ext/ruby_prof/vc/{ruby_prof_20.vcxproj → ruby_prof.vcxproj} +38 -5
  31. data/lib/ruby-prof.rb +52 -58
  32. data/lib/ruby-prof/assets/call_stack_printer.html.erb +713 -0
  33. data/lib/ruby-prof/assets/call_stack_printer.png +0 -0
  34. data/lib/ruby-prof/assets/graph_printer.html.erb +356 -0
  35. data/lib/ruby-prof/call_info.rb +57 -126
  36. data/lib/ruby-prof/call_info_visitor.rb +38 -40
  37. data/lib/ruby-prof/compatibility.rb +109 -178
  38. data/lib/ruby-prof/exclude_common_methods.rb +198 -0
  39. data/lib/ruby-prof/measurement.rb +14 -0
  40. data/lib/ruby-prof/method_info.rb +90 -129
  41. data/lib/ruby-prof/printers/abstract_printer.rb +127 -85
  42. data/lib/ruby-prof/printers/call_info_printer.rb +51 -41
  43. data/lib/ruby-prof/printers/call_stack_printer.rb +182 -260
  44. data/lib/ruby-prof/printers/call_tree_printer.rb +151 -130
  45. data/lib/ruby-prof/printers/dot_printer.rb +132 -132
  46. data/lib/ruby-prof/printers/flat_printer.rb +52 -70
  47. data/lib/ruby-prof/printers/graph_html_printer.rb +63 -244
  48. data/lib/ruby-prof/printers/graph_printer.rb +114 -116
  49. data/lib/ruby-prof/printers/multi_printer.rb +127 -58
  50. data/lib/ruby-prof/profile.rb +33 -55
  51. data/lib/ruby-prof/rack.rb +171 -95
  52. data/lib/ruby-prof/task.rb +147 -147
  53. data/lib/ruby-prof/thread.rb +35 -41
  54. data/lib/ruby-prof/version.rb +3 -3
  55. data/lib/unprof.rb +10 -10
  56. data/ruby-prof.gemspec +58 -57
  57. data/test/abstract_printer_test.rb +26 -0
  58. data/test/alias_test.rb +129 -0
  59. data/test/basic_test.rb +129 -128
  60. data/test/call_info_visitor_test.rb +31 -31
  61. data/test/duplicate_names_test.rb +32 -32
  62. data/test/dynamic_method_test.rb +53 -55
  63. data/test/enumerable_test.rb +21 -21
  64. data/test/exceptions_test.rb +24 -16
  65. data/test/exclude_methods_test.rb +146 -0
  66. data/test/exclude_threads_test.rb +53 -53
  67. data/test/fiber_test.rb +73 -79
  68. data/test/gc_test.rb +96 -0
  69. data/test/line_number_test.rb +161 -71
  70. data/test/marshal_test.rb +119 -0
  71. data/test/measure_allocations.rb +30 -0
  72. data/test/measure_allocations_test.rb +385 -26
  73. data/test/measure_allocations_trace_test.rb +385 -0
  74. data/test/measure_memory_trace_test.rb +756 -0
  75. data/test/measure_process_time_test.rb +849 -63
  76. data/test/measure_times.rb +54 -0
  77. data/test/measure_wall_time_test.rb +459 -255
  78. data/test/multi_printer_test.rb +71 -83
  79. data/test/no_method_class_test.rb +15 -15
  80. data/test/parser_timings.rb +24 -0
  81. data/test/pause_resume_test.rb +166 -166
  82. data/test/prime.rb +56 -54
  83. data/test/printer_call_stack_test.rb +28 -0
  84. data/test/printer_call_tree_test.rb +31 -0
  85. data/test/printer_flat_test.rb +68 -0
  86. data/test/printer_graph_html_test.rb +60 -0
  87. data/test/printer_graph_test.rb +41 -0
  88. data/test/printers_test.rb +141 -255
  89. data/test/printing_recursive_graph_test.rb +81 -127
  90. data/test/rack_test.rb +157 -93
  91. data/test/recursive_test.rb +210 -215
  92. data/test/singleton_test.rb +38 -38
  93. data/test/stack_printer_test.rb +64 -78
  94. data/test/start_stop_test.rb +109 -112
  95. data/test/test_helper.rb +24 -264
  96. data/test/thread_test.rb +144 -187
  97. data/test/unique_call_path_test.rb +190 -202
  98. data/test/yarv_test.rb +56 -55
  99. metadata +34 -114
  100. data/doc/LICENSE.html +0 -114
  101. data/doc/README_rdoc.html +0 -603
  102. data/doc/Rack.html +0 -95
  103. data/doc/Rack/RubyProf.html +0 -226
  104. data/doc/RubyProf.html +0 -962
  105. data/doc/RubyProf/AbstractPrinter.html +0 -546
  106. data/doc/RubyProf/AggregateCallInfo.html +0 -551
  107. data/doc/RubyProf/CallInfo.html +0 -639
  108. data/doc/RubyProf/CallInfoPrinter.html +0 -120
  109. data/doc/RubyProf/CallInfoVisitor.html +0 -198
  110. data/doc/RubyProf/CallStackPrinter.html +0 -1121
  111. data/doc/RubyProf/CallTreePrinter.html +0 -641
  112. data/doc/RubyProf/Cmd.html +0 -631
  113. data/doc/RubyProf/DotPrinter.html +0 -257
  114. data/doc/RubyProf/FlatPrinter.html +0 -163
  115. data/doc/RubyProf/FlatPrinterWithLineNumbers.html +0 -208
  116. data/doc/RubyProf/GraphHtmlPrinter.html +0 -552
  117. data/doc/RubyProf/GraphPrinter.html +0 -139
  118. data/doc/RubyProf/MethodInfo.html +0 -745
  119. data/doc/RubyProf/MultiPrinter.html +0 -360
  120. data/doc/RubyProf/Profile.html +0 -763
  121. data/doc/RubyProf/ProfileTask.html +0 -490
  122. data/doc/RubyProf/Thread.html +0 -310
  123. data/doc/created.rid +0 -31
  124. data/doc/css/fonts.css +0 -167
  125. data/doc/css/rdoc.css +0 -590
  126. data/doc/examples/flat_txt.html +0 -138
  127. data/doc/examples/graph_html.html +0 -909
  128. data/doc/examples/graph_txt.html +0 -247
  129. data/doc/fonts/Lato-Light.ttf +0 -0
  130. data/doc/fonts/Lato-LightItalic.ttf +0 -0
  131. data/doc/fonts/Lato-Regular.ttf +0 -0
  132. data/doc/fonts/Lato-RegularItalic.ttf +0 -0
  133. data/doc/fonts/SourceCodePro-Bold.ttf +0 -0
  134. data/doc/fonts/SourceCodePro-Regular.ttf +0 -0
  135. data/doc/images/add.png +0 -0
  136. data/doc/images/arrow_up.png +0 -0
  137. data/doc/images/brick.png +0 -0
  138. data/doc/images/brick_link.png +0 -0
  139. data/doc/images/bug.png +0 -0
  140. data/doc/images/bullet_black.png +0 -0
  141. data/doc/images/bullet_toggle_minus.png +0 -0
  142. data/doc/images/bullet_toggle_plus.png +0 -0
  143. data/doc/images/date.png +0 -0
  144. data/doc/images/delete.png +0 -0
  145. data/doc/images/find.png +0 -0
  146. data/doc/images/loadingAnimation.gif +0 -0
  147. data/doc/images/macFFBgHack.png +0 -0
  148. data/doc/images/package.png +0 -0
  149. data/doc/images/page_green.png +0 -0
  150. data/doc/images/page_white_text.png +0 -0
  151. data/doc/images/page_white_width.png +0 -0
  152. data/doc/images/plugin.png +0 -0
  153. data/doc/images/ruby.png +0 -0
  154. data/doc/images/tag_blue.png +0 -0
  155. data/doc/images/tag_green.png +0 -0
  156. data/doc/images/transparent.png +0 -0
  157. data/doc/images/wrench.png +0 -0
  158. data/doc/images/wrench_orange.png +0 -0
  159. data/doc/images/zoom.png +0 -0
  160. data/doc/index.html +0 -626
  161. data/doc/js/darkfish.js +0 -161
  162. data/doc/js/jquery.js +0 -4
  163. data/doc/js/navigation.js +0 -142
  164. data/doc/js/navigation.js.gz +0 -0
  165. data/doc/js/search.js +0 -109
  166. data/doc/js/search_index.js +0 -1
  167. data/doc/js/search_index.js.gz +0 -0
  168. data/doc/js/searcher.js +0 -228
  169. data/doc/js/searcher.js.gz +0 -0
  170. data/doc/table_of_contents.html +0 -942
  171. data/examples/cachegrind.out.1 +0 -114
  172. data/examples/cachegrind.out.1.32313213 +0 -114
  173. data/examples/flat.txt +0 -50
  174. data/examples/graph.dot +0 -84
  175. data/examples/graph.html +0 -823
  176. data/examples/graph.txt +0 -139
  177. data/examples/multi.flat.txt +0 -23
  178. data/examples/multi.graph.html +0 -760
  179. data/examples/multi.grind.dat +0 -114
  180. data/examples/multi.stack.html +0 -547
  181. data/examples/stack.html +0 -547
  182. data/ext/ruby_prof/rp_measure.c +0 -40
  183. data/ext/ruby_prof/rp_measure.h +0 -45
  184. data/ext/ruby_prof/rp_measure_cpu_time.c +0 -136
  185. data/ext/ruby_prof/rp_measure_gc_runs.c +0 -73
  186. data/ext/ruby_prof/rp_measure_gc_time.c +0 -60
  187. data/ext/ruby_prof/vc/ruby_prof_18.vcxproj +0 -108
  188. data/ext/ruby_prof/vc/ruby_prof_19.vcxproj +0 -110
  189. data/lib/ruby-prof/aggregate_call_info.rb +0 -76
  190. data/lib/ruby-prof/assets/call_stack_printer.css.html +0 -117
  191. data/lib/ruby-prof/assets/call_stack_printer.js.html +0 -385
  192. data/lib/ruby-prof/printers/flat_printer_with_line_numbers.rb +0 -64
  193. data/test/aggregate_test.rb +0 -136
  194. data/test/block_test.rb +0 -74
  195. data/test/call_info_test.rb +0 -78
  196. data/test/issue137_test.rb +0 -63
  197. data/test/measure_cpu_time_test.rb +0 -213
  198. data/test/measure_gc_runs_test.rb +0 -32
  199. data/test/measure_gc_time_test.rb +0 -36
  200. data/test/measure_memory_test.rb +0 -33
  201. data/test/method_elimination_test.rb +0 -84
  202. data/test/module_test.rb +0 -45
  203. data/test/stack_test.rb +0 -138
@@ -1,53 +1,53 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
-
6
-
7
- # -- Tests ----
8
- class ExcludeThreadsTest < TestCase
9
- def test_exclude_threads
10
-
11
- def thread1_proc
12
- sleep(0.5)
13
- sleep(2)
14
- end
15
-
16
- def thread2_proc
17
- sleep(0.5)
18
- sleep(2)
19
- end
20
-
21
- thread1 = Thread.new do
22
- thread1_proc
23
- end
24
-
25
- thread2 = Thread.new do
26
- thread2_proc
27
- end
28
-
29
- # exclude_threads already includes the minitest thread pool
30
- RubyProf.exclude_threads += [ thread2 ]
31
-
32
- RubyProf.start
33
-
34
- thread1.join
35
- thread2.join
36
-
37
- result = RubyProf.stop
38
-
39
- assert_equal(2, result.threads.length)
40
-
41
- output = Array.new
42
- result.threads.each do |thread|
43
- thread.methods.each do | m |
44
- if m.full_name.index("ExcludeThreadsTest#thread") == 0
45
- output.push(m.full_name)
46
- end
47
- end
48
- end
49
-
50
- assert_equal(1, output.length)
51
- assert_equal("ExcludeThreadsTest#thread1_proc", output[0])
52
- end
53
- end
1
+ #!/usr/bin/env ruby
2
+ # encoding: UTF-8
3
+
4
+ require File.expand_path('../test_helper', __FILE__)
5
+
6
+
7
+ # -- Tests ----
8
+ class ExcludeThreadsTest < TestCase
9
+ def test_exclude_threads
10
+
11
+ def thread1_proc
12
+ sleep(0.5)
13
+ sleep(2)
14
+ end
15
+
16
+ def thread2_proc
17
+ sleep(0.5)
18
+ sleep(2)
19
+ end
20
+
21
+ thread1 = Thread.new do
22
+ thread1_proc
23
+ end
24
+
25
+ thread2 = Thread.new do
26
+ thread2_proc
27
+ end
28
+
29
+ # exclude_threads already includes the minitest thread pool
30
+ RubyProf.exclude_threads += [ thread2 ]
31
+
32
+ RubyProf.start
33
+
34
+ thread1.join
35
+ thread2.join
36
+
37
+ result = RubyProf.stop
38
+
39
+ assert_equal(2, result.threads.length)
40
+
41
+ output = Array.new
42
+ result.threads.each do |thread|
43
+ thread.methods.each do | m |
44
+ if m.full_name.index("ExcludeThreadsTest#thread") == 0
45
+ output.push(m.full_name)
46
+ end
47
+ end
48
+ end
49
+
50
+ assert_equal(1, output.length)
51
+ assert_equal("ExcludeThreadsTest#thread1_proc", output[0])
52
+ end
53
+ end
@@ -1,79 +1,73 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
- require 'timeout'
6
- require 'set'
7
- begin
8
- require 'fiber'
9
- rescue LoadError
10
- end
11
-
12
- # -- Tests ----
13
- class FiberTest < TestCase
14
-
15
- def fiber_test
16
- @fiber_ids << Fiber.current.object_id
17
- enum = Enumerator.new do |yielder|
18
- [1,2].each do |x|
19
- @fiber_ids << Fiber.current.object_id
20
- sleep 0.1
21
- yielder.yield x
22
- end
23
- end
24
- while true
25
- begin
26
- enum.next
27
- rescue StopIteration
28
- break
29
- end
30
- end
31
- sleep 0.1
32
- end
33
-
34
- def setup
35
- # Need to use wall time for this test due to the sleep calls
36
- RubyProf::measure_mode = RubyProf::WALL_TIME
37
- @fiber_ids = Set.new
38
- @root_fiber = Fiber.current.object_id
39
- @thread_id = Thread.current.object_id
40
- end
41
-
42
- def test_fibers
43
- result = RubyProf.profile { fiber_test }
44
- profiled_fiber_ids = result.threads.map(&:fiber_id)
45
- assert_equal(2, result.threads.length)
46
- assert_equal([@thread_id], result.threads.map(&:id).uniq)
47
- assert_equal(@fiber_ids, Set.new(profiled_fiber_ids))
48
-
49
- assert profiled_fiber_ids.include?(@root_fiber)
50
- assert(root_fiber_profile = result.threads.detect{|t| t.fiber_id == @root_fiber})
51
- assert(enum_fiber_profile = result.threads.detect{|t| t.fiber_id != @root_fiber})
52
-
53
- assert_in_delta(0.3, root_fiber_profile.total_time, 0.05)
54
- assert_in_delta(0.2, enum_fiber_profile.total_time, 0.05)
55
-
56
- assert(method_next = root_fiber_profile.methods.detect{|m| m.full_name == "Enumerator#next"})
57
- assert(method_each = enum_fiber_profile.methods.detect{|m| m.full_name == "Enumerator#each"})
58
-
59
- assert_in_delta(0.2, method_next.total_time, 0.05)
60
- assert_in_delta(0.2, method_each.total_time, 0.05)
61
- end
62
-
63
- def test_merged_fibers
64
- result = RubyProf.profile(merge_fibers: true) { fiber_test }
65
- assert_equal(1, result.threads.length)
66
-
67
- profile = result.threads.first
68
- assert_equal 0, profile.fiber_id
69
-
70
- assert_in_delta(0.3, profile.total_time, 0.05)
71
-
72
- assert(method_next = profile.methods.detect{|m| m.full_name == "Enumerator#next"})
73
- assert(method_each = profile.methods.detect{|m| m.full_name == "Enumerator#each"})
74
-
75
- assert_in_delta(0.2, method_next.total_time, 0.05)
76
- assert_in_delta(0.2, method_each.total_time, 0.05)
77
- end
78
-
79
- end
1
+ #!/usr/bin/env ruby
2
+ # encoding: UTF-8
3
+
4
+ require File.expand_path('../test_helper', __FILE__)
5
+ require 'fiber'
6
+ require 'timeout'
7
+ require 'set'
8
+
9
+ # -- Tests ----
10
+ class FiberTest < TestCase
11
+ def fiber_test
12
+ @fiber_ids << Fiber.current.object_id
13
+ enum = Enumerator.new do |yielder|
14
+ [1,2].each do |x|
15
+ @fiber_ids << Fiber.current.object_id
16
+ sleep 0.1
17
+ yielder.yield x
18
+ end
19
+ end
20
+ while true
21
+ begin
22
+ enum.next
23
+ rescue StopIteration
24
+ break
25
+ end
26
+ end
27
+ sleep 0.1
28
+ end
29
+
30
+ def setup
31
+ # Need to use wall time for this test due to the sleep calls
32
+ RubyProf::measure_mode = RubyProf::WALL_TIME
33
+ @fiber_ids = Set.new
34
+ @root_fiber = Fiber.current.object_id
35
+ @thread_id = Thread.current.object_id
36
+ end
37
+
38
+ def test_fibers
39
+ result = RubyProf.profile { fiber_test }
40
+ profiled_fiber_ids = result.threads.map(&:fiber_id)
41
+ assert_equal(2, result.threads.length)
42
+ assert_equal([@thread_id], result.threads.map(&:id).uniq)
43
+ assert_equal(@fiber_ids, Set.new(profiled_fiber_ids))
44
+
45
+ assert profiled_fiber_ids.include?(@root_fiber)
46
+ assert(root_fiber_profile = result.threads.detect{|t| t.fiber_id == @root_fiber})
47
+ assert(enum_fiber_profile = result.threads.detect{|t| t.fiber_id != @root_fiber})
48
+
49
+ assert_in_delta(0.3, root_fiber_profile.total_time, 0.05)
50
+ assert_in_delta(0.2, enum_fiber_profile.total_time, 0.05)
51
+
52
+ assert(method_next = root_fiber_profile.methods.detect{|m| m.full_name == "Enumerator#next"})
53
+ assert(method_each = enum_fiber_profile.methods.detect{|m| m.full_name == "Enumerator#each"})
54
+
55
+ assert_in_delta(0.2, method_next.total_time, 0.05)
56
+ assert_in_delta(0.2, method_each.total_time, 0.05)
57
+ end
58
+
59
+ def test_merged_fibers
60
+ result = RubyProf.profile(merge_fibers: true) { fiber_test }
61
+ assert_equal(1, result.threads.length)
62
+
63
+ thread = result.threads.first
64
+ assert_equal(thread.id, thread.fiber_id)
65
+ assert_in_delta(0.3, thread.total_time, 0.05)
66
+
67
+ assert(method_next = thread.methods.detect{|m| m.full_name == "Enumerator#next"})
68
+ assert(method_each = thread.methods.detect{|m| m.full_name == "Enumerator#each"})
69
+
70
+ assert_in_delta(0.2, method_next.total_time, 0.05)
71
+ assert_in_delta(0.2, method_each.total_time, 0.05)
72
+ end
73
+ end
@@ -0,0 +1,96 @@
1
+ #!/usr/bin/env ruby
2
+ # encoding: UTF-8
3
+
4
+ require File.expand_path('../test_helper', __FILE__)
5
+
6
+ class GcTest < TestCase
7
+ def some_method
8
+ Array.new(3 * 4)
9
+ end
10
+
11
+ def run_profile
12
+ RubyProf.profile do
13
+ self.some_method
14
+ end
15
+ end
16
+
17
+ def test_hold_onto_thread
18
+ threads = 1000.times.reduce(Array.new) do |array, i|
19
+ array.concat(run_profile.threads)
20
+ GC.start
21
+ array
22
+ end
23
+
24
+ threads.each do |thread|
25
+ error = assert_raises(RuntimeError) do
26
+ thread.id
27
+ end
28
+ assert_match(/has already been freed/, error.message)
29
+ end
30
+ assert(true)
31
+ end
32
+
33
+ def test_hold_onto_method
34
+ methods = 1000.times.reduce(Array.new) do |array, i|
35
+ array.concat(run_profile.threads.map(&:methods).flatten)
36
+ GC.start
37
+ array
38
+ end
39
+
40
+ methods.each do |method|
41
+ error = assert_raises(RuntimeError) do
42
+ method.method_name
43
+ end
44
+ assert_match(/has already been freed/, error.message)
45
+ end
46
+ assert(true)
47
+ end
48
+
49
+ def test_hold_onto_parent_callers
50
+ call_infos = 1000.times.reduce(Array.new) do |array, i|
51
+ array.concat(run_profile.threads.map(&:methods).flatten.map(&:callers).flatten)
52
+ GC.start
53
+ array
54
+ end
55
+
56
+ call_infos.each do |call_info|
57
+ error = assert_raises(RuntimeError) do
58
+ call_info.source_file
59
+ end
60
+ assert_match(/has already been freed/, error.message)
61
+ end
62
+ assert(true)
63
+ end
64
+
65
+ def test_hold_onto_parent_callees
66
+ call_infos = 1000.times.reduce(Array.new) do |array, i|
67
+ array.concat(run_profile.threads.map(&:methods).flatten.map(&:callees).flatten)
68
+ GC.start
69
+ array
70
+ end
71
+
72
+ call_infos.each do |call_info|
73
+ error = assert_raises(RuntimeError) do
74
+ call_info.source_file
75
+ end
76
+ assert_match(/has already been freed/, error.message)
77
+ end
78
+ assert(true)
79
+ end
80
+
81
+ def test_hold_onto_measurements
82
+ measurements = 1000.times.reduce(Array.new) do |array, i|
83
+ array.concat(run_profile.threads.map(&:methods).flatten.map(&:callers).flatten.map(&:measurement))
84
+ GC.start
85
+ array
86
+ end
87
+
88
+ measurements.each do |measurement|
89
+ error = assert_raises(RuntimeError) do
90
+ measurement.total_time
91
+ end
92
+ assert_match(/has already been freed/, error.message)
93
+ end
94
+ assert(true)
95
+ end
96
+ end
@@ -1,71 +1,161 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
-
6
- class LineNumbers
7
- def method1
8
- end
9
-
10
- def method2
11
- method1
12
- end
13
-
14
- def method3
15
- sleep(1)
16
- end
17
- end
18
-
19
- # -- Tests ----
20
- class LineNumbersTest < TestCase
21
- def test_function_line_no
22
- numbers = LineNumbers.new
23
-
24
- result = RubyProf.profile do
25
- numbers.method2
26
- end
27
-
28
- methods = result.threads.first.methods.sort.reverse
29
- assert_equal(3, methods.length)
30
-
31
- method = methods[0]
32
- assert_equal('LineNumbersTest#test_function_line_no', method.full_name)
33
- assert_equal(25, method.line)
34
-
35
- method = methods[1]
36
- assert_equal('LineNumbers#method2', method.full_name)
37
- assert_equal(10, method.line)
38
-
39
- method = methods[2]
40
- assert_equal('LineNumbers#method1', method.full_name)
41
- assert_equal(7, method.line)
42
- end
43
-
44
- def test_c_function
45
- numbers = LineNumbers.new
46
-
47
- result = RubyProf.profile do
48
- numbers.method3
49
- end
50
-
51
- methods = result.threads.first.methods.sort_by {|method| method.full_name}
52
- assert_equal(3, methods.length)
53
-
54
- # Methods:
55
- # LineNumbers#method3
56
- # LineNumbersTest#test_c_function
57
- # Kernel#sleep
58
-
59
- method = methods[0]
60
- assert_equal('Kernel#sleep', method.full_name)
61
- assert_equal(0, method.line)
62
-
63
- method = methods[1]
64
- assert_equal('LineNumbers#method3', method.full_name)
65
- assert_equal(14, method.line)
66
-
67
- method = methods[2]
68
- assert_equal('LineNumbersTest#test_c_function', method.full_name)
69
- assert_equal(48, method.line)
70
- end
71
- end
1
+ #!/usr/bin/env ruby
2
+ # encoding: UTF-8
3
+
4
+ require File.expand_path('../test_helper', __FILE__)
5
+
6
+ class LineNumbers
7
+ def method_1
8
+ method_2
9
+ filler = 1
10
+ method_3
11
+ end
12
+
13
+ def method_2
14
+ filler = 1
15
+ 2.times do |i|
16
+ filler = 2
17
+ method_3
18
+ end
19
+ end
20
+
21
+ def method_3
22
+ sleep(0.4)
23
+ method_4
24
+ end
25
+
26
+ def method_4
27
+ sleep(1)
28
+ end
29
+ end
30
+
31
+ # -- Tests ----
32
+ class LineNumbersTest < TestCase
33
+ def test_function_line_no
34
+ numbers = LineNumbers.new
35
+
36
+ result = RubyProf.profile do
37
+ numbers.method_1
38
+ end
39
+
40
+ methods = result.threads.first.methods.sort.reverse
41
+ assert_equal(7, methods.length)
42
+
43
+ # Method 0
44
+ method = methods[0]
45
+ assert_equal('LineNumbersTest#test_function_line_no', method.full_name)
46
+ assert_equal(37, method.line)
47
+
48
+ assert_equal(1, method.callers.count)
49
+ call_info = method.callers[0]
50
+ assert_nil(call_info.parent)
51
+ assert_equal(37, call_info.line)
52
+
53
+ assert_equal(1, method.callees.count)
54
+ call_info = method.callees[0]
55
+ assert_equal('LineNumbers#method_1', call_info.target.full_name)
56
+ assert_equal(37, call_info.line)
57
+
58
+ # Method 1
59
+ method = methods[1]
60
+ assert_equal('LineNumbers#method_1', method.full_name)
61
+ assert_equal(7, method.line)
62
+
63
+ assert_equal(1, method.callers.count)
64
+ call_info = method.callers[0]
65
+ assert_equal('LineNumbersTest#test_function_line_no', call_info.parent.full_name)
66
+ assert_equal(37, call_info.line)
67
+
68
+ assert_equal(2, method.callees.count)
69
+ call_info = method.callees[0]
70
+ assert_equal('LineNumbers#method_2', call_info.target.full_name)
71
+ assert_equal(8, call_info.line)
72
+
73
+ call_info = method.callees[1]
74
+ assert_equal('LineNumbers#method_3', call_info.target.full_name)
75
+ assert_equal(10, call_info.line)
76
+
77
+ # Method 2
78
+ method = methods[2]
79
+ assert_equal('LineNumbers#method_3', method.full_name)
80
+ assert_equal(21, method.line)
81
+
82
+ assert_equal(2, method.callers.count)
83
+ call_info = method.callers[0]
84
+ assert_equal('Integer#times', call_info.parent.full_name)
85
+ assert_equal(17, call_info.line)
86
+
87
+ call_info = method.callers[1]
88
+ assert_equal('LineNumbers#method_1', call_info.parent.full_name)
89
+ assert_equal(10, call_info.line)
90
+
91
+ assert_equal(2, method.callees.count)
92
+ call_info = method.callees[0]
93
+ assert_equal('Kernel#sleep', call_info.target.full_name)
94
+ assert_equal(22, call_info.line)
95
+
96
+ call_info = method.callees[1]
97
+ assert_equal('LineNumbers#method_4', call_info.target.full_name)
98
+ assert_equal(23, call_info.line)
99
+
100
+ # Method 3
101
+ method = methods[3]
102
+ assert_equal('Kernel#sleep', method.full_name)
103
+ assert_equal(0, method.line)
104
+
105
+ assert_equal(2, method.callers.count)
106
+ call_info = method.callers[0]
107
+ assert_equal('LineNumbers#method_3', call_info.parent.full_name)
108
+ assert_equal(22, call_info.line)
109
+
110
+ call_info = method.callers[1]
111
+ assert_equal('LineNumbers#method_4', call_info.parent.full_name)
112
+ assert_equal(27, call_info.line)
113
+
114
+ assert_equal(0, method.callees.count)
115
+
116
+ # Method 4
117
+ method = methods[4]
118
+ assert_equal('LineNumbers#method_4', method.full_name)
119
+ assert_equal(26, method.line)
120
+
121
+ assert_equal(1, method.callers.count)
122
+ call_info = method.callers[0]
123
+ assert_equal('LineNumbers#method_3', call_info.parent.full_name)
124
+ assert_equal(23, call_info.line)
125
+
126
+ assert_equal(1, method.callees.count)
127
+ call_info = method.callees[0]
128
+ assert_equal('Kernel#sleep', call_info.target.full_name)
129
+ assert_equal(27, call_info.line)
130
+
131
+ # Method 5
132
+ method = methods[5]
133
+ assert_equal('LineNumbers#method_2', method.full_name)
134
+ assert_equal(13, method.line)
135
+
136
+ assert_equal(1, method.callers.count)
137
+ call_info = method.callers[0]
138
+ assert_equal('LineNumbers#method_1', call_info.parent.full_name)
139
+ assert_equal(8, call_info.line)
140
+
141
+ assert_equal(1, method.callees.count)
142
+ call_info = method.callees[0]
143
+ assert_equal('Integer#times', call_info.target.full_name)
144
+ assert_equal(15, call_info.line)
145
+
146
+ # Method 6
147
+ method = methods[6]
148
+ assert_equal('Integer#times', method.full_name)
149
+ assert_equal(0, method.line)
150
+
151
+ assert_equal(1, method.callers.count)
152
+ call_info = method.callers[0]
153
+ assert_equal('LineNumbers#method_2', call_info.parent.full_name)
154
+ assert_equal(15, call_info.line)
155
+
156
+ assert_equal(1, method.callees.count)
157
+ call_info = method.callees[0]
158
+ assert_equal('LineNumbers#method_3', call_info.target.full_name)
159
+ assert_equal(17, call_info.line)
160
+ end
161
+ end