ruby-prof 0.17.0 → 0.18.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 (185) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGES +500 -482
  3. data/LICENSE +24 -24
  4. data/README.rdoc +487 -485
  5. data/Rakefile +113 -113
  6. data/bin/ruby-prof +345 -345
  7. data/bin/ruby-prof-check-trace +45 -45
  8. data/examples/flat.txt +50 -50
  9. data/examples/graph.dot +84 -84
  10. data/examples/graph.html +823 -823
  11. data/examples/graph.txt +139 -139
  12. data/examples/multi.flat.txt +23 -23
  13. data/examples/multi.graph.html +760 -760
  14. data/examples/multi.grind.dat +114 -114
  15. data/examples/multi.stack.html +547 -547
  16. data/examples/stack.html +547 -547
  17. data/ext/ruby_prof/extconf.rb +68 -68
  18. data/ext/ruby_prof/rp_call_info.c +425 -425
  19. data/ext/ruby_prof/rp_call_info.h +53 -53
  20. data/ext/ruby_prof/rp_measure.c +40 -40
  21. data/ext/ruby_prof/rp_measure.h +45 -45
  22. data/ext/ruby_prof/rp_measure_allocations.c +76 -76
  23. data/ext/ruby_prof/rp_measure_cpu_time.c +136 -136
  24. data/ext/ruby_prof/rp_measure_gc_runs.c +73 -73
  25. data/ext/ruby_prof/rp_measure_gc_time.c +60 -60
  26. data/ext/ruby_prof/rp_measure_memory.c +77 -77
  27. data/ext/ruby_prof/rp_measure_process_time.c +71 -71
  28. data/ext/ruby_prof/rp_measure_wall_time.c +45 -45
  29. data/ext/ruby_prof/rp_method.c +630 -636
  30. data/ext/ruby_prof/rp_method.h +75 -75
  31. data/ext/ruby_prof/rp_stack.c +173 -173
  32. data/ext/ruby_prof/rp_stack.h +63 -63
  33. data/ext/ruby_prof/rp_thread.c +277 -276
  34. data/ext/ruby_prof/rp_thread.h +27 -27
  35. data/ext/ruby_prof/ruby_prof.c +794 -774
  36. data/ext/ruby_prof/ruby_prof.h +60 -59
  37. data/ext/ruby_prof/vc/ruby_prof.sln +20 -21
  38. data/ext/ruby_prof/vc/{ruby_prof_20.vcxproj → ruby_prof.vcxproj} +31 -0
  39. data/lib/ruby-prof.rb +68 -68
  40. data/lib/ruby-prof/aggregate_call_info.rb +76 -76
  41. data/lib/ruby-prof/assets/call_stack_printer.css.html +116 -116
  42. data/lib/ruby-prof/assets/call_stack_printer.js.html +384 -384
  43. data/lib/ruby-prof/call_info.rb +115 -115
  44. data/lib/ruby-prof/call_info_visitor.rb +40 -40
  45. data/lib/ruby-prof/compatibility.rb +179 -178
  46. data/lib/ruby-prof/method_info.rb +121 -121
  47. data/lib/ruby-prof/printers/abstract_printer.rb +104 -103
  48. data/lib/ruby-prof/printers/call_info_printer.rb +41 -41
  49. data/lib/ruby-prof/printers/call_stack_printer.rb +265 -265
  50. data/lib/ruby-prof/printers/call_tree_printer.rb +143 -143
  51. data/lib/ruby-prof/printers/dot_printer.rb +132 -132
  52. data/lib/ruby-prof/printers/flat_printer.rb +70 -70
  53. data/lib/ruby-prof/printers/flat_printer_with_line_numbers.rb +83 -83
  54. data/lib/ruby-prof/printers/graph_html_printer.rb +249 -249
  55. data/lib/ruby-prof/printers/graph_printer.rb +116 -116
  56. data/lib/ruby-prof/printers/multi_printer.rb +84 -84
  57. data/lib/ruby-prof/profile.rb +26 -26
  58. data/lib/ruby-prof/profile/exclude_common_methods.rb +207 -201
  59. data/lib/ruby-prof/profile/legacy_method_elimination.rb +50 -49
  60. data/lib/ruby-prof/rack.rb +174 -174
  61. data/lib/ruby-prof/task.rb +147 -147
  62. data/lib/ruby-prof/thread.rb +35 -35
  63. data/lib/ruby-prof/version.rb +3 -3
  64. data/lib/unprof.rb +10 -10
  65. data/ruby-prof.gemspec +58 -58
  66. data/test/abstract_printer_test.rb +53 -0
  67. data/test/aggregate_test.rb +136 -136
  68. data/test/basic_test.rb +128 -128
  69. data/test/block_test.rb +74 -74
  70. data/test/call_info_test.rb +78 -78
  71. data/test/call_info_visitor_test.rb +31 -31
  72. data/test/duplicate_names_test.rb +32 -32
  73. data/test/dynamic_method_test.rb +55 -55
  74. data/test/enumerable_test.rb +21 -21
  75. data/test/exceptions_test.rb +24 -16
  76. data/test/exclude_methods_test.rb +146 -146
  77. data/test/exclude_threads_test.rb +53 -53
  78. data/test/fiber_test.rb +79 -79
  79. data/test/issue137_test.rb +63 -63
  80. data/test/line_number_test.rb +80 -80
  81. data/test/measure_allocations_test.rb +26 -26
  82. data/test/measure_cpu_time_test.rb +212 -213
  83. data/test/measure_gc_runs_test.rb +32 -32
  84. data/test/measure_gc_time_test.rb +36 -36
  85. data/test/measure_memory_test.rb +33 -33
  86. data/test/measure_process_time_test.rb +61 -63
  87. data/test/measure_wall_time_test.rb +255 -255
  88. data/test/method_elimination_test.rb +84 -84
  89. data/test/module_test.rb +45 -45
  90. data/test/multi_printer_test.rb +104 -104
  91. data/test/no_method_class_test.rb +15 -15
  92. data/test/pause_resume_test.rb +166 -166
  93. data/test/prime.rb +54 -54
  94. data/test/printers_test.rb +275 -275
  95. data/test/printing_recursive_graph_test.rb +127 -127
  96. data/test/rack_test.rb +157 -157
  97. data/test/recursive_test.rb +215 -215
  98. data/test/singleton_test.rb +38 -38
  99. data/test/stack_printer_test.rb +77 -78
  100. data/test/stack_test.rb +138 -138
  101. data/test/start_stop_test.rb +112 -112
  102. data/test/test_helper.rb +267 -275
  103. data/test/thread_test.rb +187 -187
  104. data/test/unique_call_path_test.rb +202 -202
  105. data/test/yarv_test.rb +55 -55
  106. metadata +17 -96
  107. data/doc/LICENSE.html +0 -115
  108. data/doc/README_rdoc.html +0 -637
  109. data/doc/Rack.html +0 -96
  110. data/doc/Rack/RubyProf.html +0 -233
  111. data/doc/Rack/RubyProf/RackProfiler.html +0 -343
  112. data/doc/RubyProf.html +0 -974
  113. data/doc/RubyProf/AbstractPrinter.html +0 -625
  114. data/doc/RubyProf/AggregateCallInfo.html +0 -552
  115. data/doc/RubyProf/CallInfo.html +0 -579
  116. data/doc/RubyProf/CallInfoPrinter.html +0 -121
  117. data/doc/RubyProf/CallInfoVisitor.html +0 -199
  118. data/doc/RubyProf/CallStackPrinter.html +0 -1127
  119. data/doc/RubyProf/CallTreePrinter.html +0 -725
  120. data/doc/RubyProf/Cmd.html +0 -637
  121. data/doc/RubyProf/DeprecationWarnings.html +0 -148
  122. data/doc/RubyProf/DotPrinter.html +0 -258
  123. data/doc/RubyProf/FlatPrinter.html +0 -164
  124. data/doc/RubyProf/FlatPrinterWithLineNumbers.html +0 -210
  125. data/doc/RubyProf/GraphHtmlPrinter.html +0 -558
  126. data/doc/RubyProf/GraphPrinter.html +0 -140
  127. data/doc/RubyProf/MethodInfo.html +0 -676
  128. data/doc/RubyProf/MultiPrinter.html +0 -574
  129. data/doc/RubyProf/Profile.html +0 -908
  130. data/doc/RubyProf/Profile/ExcludeCommonMethods.html +0 -411
  131. data/doc/RubyProf/Profile/LegacyMethodElimination.html +0 -158
  132. data/doc/RubyProf/ProfileTask.html +0 -491
  133. data/doc/RubyProf/Thread.html +0 -275
  134. data/doc/created.rid +0 -33
  135. data/doc/css/fonts.css +0 -167
  136. data/doc/css/rdoc.css +0 -590
  137. data/doc/examples/flat_txt.html +0 -139
  138. data/doc/examples/graph_html.html +0 -910
  139. data/doc/examples/graph_txt.html +0 -248
  140. data/doc/fonts/Lato-Light.ttf +0 -0
  141. data/doc/fonts/Lato-LightItalic.ttf +0 -0
  142. data/doc/fonts/Lato-Regular.ttf +0 -0
  143. data/doc/fonts/Lato-RegularItalic.ttf +0 -0
  144. data/doc/fonts/SourceCodePro-Bold.ttf +0 -0
  145. data/doc/fonts/SourceCodePro-Regular.ttf +0 -0
  146. data/doc/images/add.png +0 -0
  147. data/doc/images/arrow_up.png +0 -0
  148. data/doc/images/brick.png +0 -0
  149. data/doc/images/brick_link.png +0 -0
  150. data/doc/images/bug.png +0 -0
  151. data/doc/images/bullet_black.png +0 -0
  152. data/doc/images/bullet_toggle_minus.png +0 -0
  153. data/doc/images/bullet_toggle_plus.png +0 -0
  154. data/doc/images/date.png +0 -0
  155. data/doc/images/delete.png +0 -0
  156. data/doc/images/find.png +0 -0
  157. data/doc/images/loadingAnimation.gif +0 -0
  158. data/doc/images/macFFBgHack.png +0 -0
  159. data/doc/images/package.png +0 -0
  160. data/doc/images/page_green.png +0 -0
  161. data/doc/images/page_white_text.png +0 -0
  162. data/doc/images/page_white_width.png +0 -0
  163. data/doc/images/plugin.png +0 -0
  164. data/doc/images/ruby.png +0 -0
  165. data/doc/images/tag_blue.png +0 -0
  166. data/doc/images/tag_green.png +0 -0
  167. data/doc/images/transparent.png +0 -0
  168. data/doc/images/wrench.png +0 -0
  169. data/doc/images/wrench_orange.png +0 -0
  170. data/doc/images/zoom.png +0 -0
  171. data/doc/index.html +0 -666
  172. data/doc/js/darkfish.js +0 -161
  173. data/doc/js/jquery.js +0 -4
  174. data/doc/js/navigation.js +0 -142
  175. data/doc/js/navigation.js.gz +0 -0
  176. data/doc/js/search.js +0 -109
  177. data/doc/js/search_index.js +0 -1
  178. data/doc/js/search_index.js.gz +0 -0
  179. data/doc/js/searcher.js +0 -229
  180. data/doc/js/searcher.js.gz +0 -0
  181. data/doc/table_of_contents.html +0 -1052
  182. data/examples/cachegrind.out.1 +0 -114
  183. data/examples/cachegrind.out.1.32313213 +0 -114
  184. data/ext/ruby_prof/vc/ruby_prof_18.vcxproj +0 -108
  185. data/ext/ruby_prof/vc/ruby_prof_19.vcxproj +0 -110
@@ -1,187 +1,187 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
- require 'timeout'
6
- require 'benchmark'
7
-
8
- # -- Tests ----
9
- class ThreadTest < TestCase
10
- def setup
11
- # Need to use wall time for this test due to the sleep calls
12
- RubyProf::measure_mode = RubyProf::WALL_TIME
13
- end
14
-
15
- def test_thread_count
16
- RubyProf.start
17
-
18
- thread = Thread.new do
19
- sleep(1)
20
- end
21
-
22
- thread.join
23
- result = RubyProf.stop
24
- assert_equal(2, result.threads.length)
25
- end
26
-
27
- def test_thread_identity
28
- RubyProf.start
29
- sleep_thread = Thread.new do
30
- sleep(1)
31
- end
32
- sleep_thread.join
33
- result = RubyProf.stop
34
-
35
- thread_ids = result.threads.map {|thread| thread.id}.sort
36
- threads = [Thread.current, sleep_thread]
37
- assert_equal(2, result.threads.length)
38
-
39
- assert(thread_ids.include?(threads[0].object_id))
40
- assert(thread_ids.include?(threads[1].object_id))
41
-
42
- assert_instance_of(Thread, ObjectSpace._id2ref(thread_ids[0]))
43
- assert(threads.include?(ObjectSpace._id2ref(thread_ids[0])))
44
-
45
- assert_instance_of(Thread, ObjectSpace._id2ref(thread_ids[1]))
46
- assert(threads.include?(ObjectSpace._id2ref(thread_ids[1])))
47
- end
48
-
49
- def test_thread_timings
50
- RubyProf.start
51
- thread = Thread.new do
52
- sleep 0
53
- # force it to hit thread.join, below, first
54
- # thus forcing sleep(1), below, to be counted as (wall) self_time
55
- # since we currently count time "in some other thread" as self.wait_time
56
- # for whatever reason
57
- sleep(1)
58
- end
59
- thread.join
60
- result = RubyProf.stop
61
-
62
- # Check background thread
63
- assert_equal(2, result.threads.length)
64
-
65
- rp_thread = result.threads.detect {|t| t.id == thread.object_id}
66
- methods = rp_thread.methods.sort.reverse
67
- # fails on travis. why?
68
- # expected_methods = ["ThreadTest#test_thread_timings", "Kernel#sleep"]
69
- # assert_equal(expected_methods, methods.map(&:full_name))
70
-
71
- method = methods[0]
72
- assert_equal('ThreadTest#test_thread_timings', method.full_name)
73
- assert_equal(1, method.called)
74
- assert_in_delta(1, method.total_time, 0.05)
75
- assert_in_delta(0, method.self_time, 0.05)
76
- assert_in_delta(0, method.wait_time, 0.05)
77
- assert_in_delta(1, method.children_time, 0.05)
78
- assert_equal(1, method.call_infos.length)
79
- call_info = method.call_infos[0]
80
- assert_equal('ThreadTest#test_thread_timings', call_info.call_sequence)
81
- assert_equal(1, call_info.children.length)
82
-
83
- method = methods[1]
84
- assert_equal('Kernel#sleep', method.full_name)
85
- assert_equal(2, method.called)
86
- assert_in_delta(1, method.total_time, 0.05)
87
- assert_in_delta(1.0, method.self_time, 0.05)
88
- assert_in_delta(0, method.wait_time, 0.05)
89
- assert_in_delta(0, method.children_time, 0.05)
90
-
91
- assert_equal(1, method.call_infos.length)
92
- call_info = method.call_infos[0]
93
- assert_equal('ThreadTest#test_thread_timings->Kernel#sleep', call_info.call_sequence)
94
- assert_equal(0, call_info.children.length)
95
-
96
- # Check foreground thread
97
- rp_thread = result.threads.detect {|athread| athread.id == Thread.current.object_id}
98
- methods = rp_thread.methods.sort.reverse
99
- assert_equal(4, methods.length)
100
- methods = methods.sort.reverse
101
-
102
- method = methods[0]
103
- assert_equal('ThreadTest#test_thread_timings', method.full_name)
104
- # the sub calls to Object#new, when popped,
105
- # cause the parent frame to be created for method #test_thread_timings, which means a +1 when it's popped in the end
106
- # xxxx a test that shows it the other way, too (never creates parent frame--if that's even possible)
107
- assert_equal(1, method.called)
108
- assert_in_delta(1, method.total_time, 0.05)
109
- assert_in_delta(0, method.self_time, 0.05)
110
- assert_in_delta(0, method.wait_time, 0.05)
111
- assert_in_delta(1, method.children_time, 0.05)
112
-
113
- assert_equal(1, method.call_infos.length)
114
- call_info = method.call_infos[0]
115
- assert_equal('ThreadTest#test_thread_timings', call_info.call_sequence)
116
- assert_equal(2, call_info.children.length)
117
-
118
- method = methods[1]
119
- assert_equal('Thread#join', method.full_name)
120
- assert_equal(1, method.called)
121
- assert_in_delta(1, method.total_time, 0.05)
122
- assert_in_delta(0, method.self_time, 0.05)
123
- assert_in_delta(1.0, method.wait_time, 0.05)
124
- assert_in_delta(0, method.children_time, 0.05)
125
-
126
- assert_equal(1, method.call_infos.length)
127
- call_info = method.call_infos[0]
128
- assert_equal('ThreadTest#test_thread_timings->Thread#join', call_info.call_sequence)
129
- assert_equal(0, call_info.children.length)
130
-
131
- method = methods[2]
132
- assert_equal('<Class::Thread>#new', method.full_name)
133
- assert_equal(1, method.called)
134
- assert_in_delta(0, method.total_time, 0.05)
135
- assert_in_delta(0, method.self_time, 0.05)
136
- assert_in_delta(0, method.wait_time, 0.05)
137
- assert_in_delta(0, method.children_time, 0.05)
138
-
139
- assert_equal(1, method.call_infos.length)
140
- call_info = method.call_infos[0]
141
- assert_equal('ThreadTest#test_thread_timings-><Class::Thread>#new', call_info.call_sequence)
142
- assert_equal(1, call_info.children.length)
143
-
144
- method = methods[3]
145
- assert_equal('Thread#initialize', method.full_name)
146
- assert_equal(1, method.called)
147
- assert_in_delta(0, method.total_time, 0.05)
148
- assert_in_delta(0, method.self_time, 0.05)
149
- assert_in_delta(0, method.wait_time, 0.05)
150
- assert_in_delta(0, method.children_time, 0.05)
151
-
152
- assert_equal(1, method.call_infos.length)
153
- call_info = method.call_infos[0]
154
- assert_equal('ThreadTest#test_thread_timings-><Class::Thread>#new->Thread#initialize', call_info.call_sequence)
155
- assert_equal(0, call_info.children.length)
156
- end
157
-
158
- # useless test: what does it test?
159
- def test_thread_back_and_forth
160
- result = nil
161
- seconds = Benchmark.realtime do
162
- result = RubyProf.profile do
163
- a = Thread.new { 100_000.times { sleep 0 }}
164
- b = Thread.new { 100_000.times { sleep 0 }}
165
- a.join
166
- b.join
167
- end
168
- end
169
- methods = result.threads.map {|thread| thread.methods}
170
- timings = methods.flatten.sort
171
- assert(timings[-1].total_time < seconds)
172
- end
173
-
174
- # useless test: what does it test?
175
- def test_thread
176
- RubyProf.profile do
177
- begin
178
- Timeout::timeout(2) do
179
- while true
180
- next
181
- end
182
- end
183
- rescue Timeout::Error
184
- end
185
- end
186
- end
187
- end
1
+ #!/usr/bin/env ruby
2
+ # encoding: UTF-8
3
+
4
+ require File.expand_path('../test_helper', __FILE__)
5
+ require 'timeout'
6
+ require 'benchmark'
7
+
8
+ # -- Tests ----
9
+ class ThreadTest < TestCase
10
+ def setup
11
+ # Need to use wall time for this test due to the sleep calls
12
+ RubyProf::measure_mode = RubyProf::WALL_TIME
13
+ end
14
+
15
+ def test_thread_count
16
+ RubyProf.start
17
+
18
+ thread = Thread.new do
19
+ sleep(1)
20
+ end
21
+
22
+ thread.join
23
+ result = RubyProf.stop
24
+ assert_equal(2, result.threads.length)
25
+ end
26
+
27
+ def test_thread_identity
28
+ RubyProf.start
29
+ sleep_thread = Thread.new do
30
+ sleep(1)
31
+ end
32
+ sleep_thread.join
33
+ result = RubyProf.stop
34
+
35
+ thread_ids = result.threads.map {|thread| thread.id}.sort
36
+ threads = [Thread.current, sleep_thread]
37
+ assert_equal(2, result.threads.length)
38
+
39
+ assert(thread_ids.include?(threads[0].object_id))
40
+ assert(thread_ids.include?(threads[1].object_id))
41
+
42
+ assert_instance_of(Thread, ObjectSpace._id2ref(thread_ids[0]))
43
+ assert(threads.include?(ObjectSpace._id2ref(thread_ids[0])))
44
+
45
+ assert_instance_of(Thread, ObjectSpace._id2ref(thread_ids[1]))
46
+ assert(threads.include?(ObjectSpace._id2ref(thread_ids[1])))
47
+ end
48
+
49
+ def test_thread_timings
50
+ RubyProf.start
51
+ thread = Thread.new do
52
+ sleep 0
53
+ # force it to hit thread.join, below, first
54
+ # thus forcing sleep(1), below, to be counted as (wall) self_time
55
+ # since we currently count time "in some other thread" as self.wait_time
56
+ # for whatever reason
57
+ sleep(1)
58
+ end
59
+ thread.join
60
+ result = RubyProf.stop
61
+
62
+ # Check background thread
63
+ assert_equal(2, result.threads.length)
64
+
65
+ rp_thread = result.threads.detect {|t| t.id == thread.object_id}
66
+ methods = rp_thread.methods.sort.reverse
67
+ # fails on travis. why?
68
+ # expected_methods = ["ThreadTest#test_thread_timings", "Kernel#sleep"]
69
+ # assert_equal(expected_methods, methods.map(&:full_name))
70
+
71
+ method = methods[0]
72
+ assert_equal('ThreadTest#test_thread_timings', method.full_name)
73
+ assert_equal(1, method.called)
74
+ assert_in_delta(1, method.total_time, 0.05)
75
+ assert_in_delta(0, method.self_time, 0.05)
76
+ assert_in_delta(0, method.wait_time, 0.05)
77
+ assert_in_delta(1, method.children_time, 0.05)
78
+ assert_equal(1, method.call_infos.length)
79
+ call_info = method.call_infos[0]
80
+ assert_equal('ThreadTest#test_thread_timings', call_info.call_sequence)
81
+ assert_equal(1, call_info.children.length)
82
+
83
+ method = methods[1]
84
+ assert_equal('Kernel#sleep', method.full_name)
85
+ assert_equal(2, method.called)
86
+ assert_in_delta(1, method.total_time, 0.05)
87
+ assert_in_delta(1.0, method.self_time, 0.05)
88
+ assert_in_delta(0, method.wait_time, 0.05)
89
+ assert_in_delta(0, method.children_time, 0.05)
90
+
91
+ assert_equal(1, method.call_infos.length)
92
+ call_info = method.call_infos[0]
93
+ assert_equal('ThreadTest#test_thread_timings->Kernel#sleep', call_info.call_sequence)
94
+ assert_equal(0, call_info.children.length)
95
+
96
+ # Check foreground thread
97
+ rp_thread = result.threads.detect {|athread| athread.id == Thread.current.object_id}
98
+ methods = rp_thread.methods.sort.reverse
99
+ assert_equal(4, methods.length)
100
+ methods = methods.sort.reverse
101
+
102
+ method = methods[0]
103
+ assert_equal('ThreadTest#test_thread_timings', method.full_name)
104
+ # the sub calls to Object#new, when popped,
105
+ # cause the parent frame to be created for method #test_thread_timings, which means a +1 when it's popped in the end
106
+ # xxxx a test that shows it the other way, too (never creates parent frame--if that's even possible)
107
+ assert_equal(1, method.called)
108
+ assert_in_delta(1, method.total_time, 0.05)
109
+ assert_in_delta(0, method.self_time, 0.05)
110
+ assert_in_delta(0, method.wait_time, 0.05)
111
+ assert_in_delta(1, method.children_time, 0.05)
112
+
113
+ assert_equal(1, method.call_infos.length)
114
+ call_info = method.call_infos[0]
115
+ assert_equal('ThreadTest#test_thread_timings', call_info.call_sequence)
116
+ assert_equal(2, call_info.children.length)
117
+
118
+ method = methods[1]
119
+ assert_equal('Thread#join', method.full_name)
120
+ assert_equal(1, method.called)
121
+ assert_in_delta(1, method.total_time, 0.05)
122
+ assert_in_delta(0, method.self_time, 0.05)
123
+ assert_in_delta(1.0, method.wait_time, 0.05)
124
+ assert_in_delta(0, method.children_time, 0.05)
125
+
126
+ assert_equal(1, method.call_infos.length)
127
+ call_info = method.call_infos[0]
128
+ assert_equal('ThreadTest#test_thread_timings->Thread#join', call_info.call_sequence)
129
+ assert_equal(0, call_info.children.length)
130
+
131
+ method = methods[2]
132
+ assert_equal('<Class::Thread>#new', method.full_name)
133
+ assert_equal(1, method.called)
134
+ assert_in_delta(0, method.total_time, 0.05)
135
+ assert_in_delta(0, method.self_time, 0.05)
136
+ assert_in_delta(0, method.wait_time, 0.05)
137
+ assert_in_delta(0, method.children_time, 0.05)
138
+
139
+ assert_equal(1, method.call_infos.length)
140
+ call_info = method.call_infos[0]
141
+ assert_equal('ThreadTest#test_thread_timings-><Class::Thread>#new', call_info.call_sequence)
142
+ assert_equal(1, call_info.children.length)
143
+
144
+ method = methods[3]
145
+ assert_equal('Thread#initialize', method.full_name)
146
+ assert_equal(1, method.called)
147
+ assert_in_delta(0, method.total_time, 0.05)
148
+ assert_in_delta(0, method.self_time, 0.05)
149
+ assert_in_delta(0, method.wait_time, 0.05)
150
+ assert_in_delta(0, method.children_time, 0.05)
151
+
152
+ assert_equal(1, method.call_infos.length)
153
+ call_info = method.call_infos[0]
154
+ assert_equal('ThreadTest#test_thread_timings-><Class::Thread>#new->Thread#initialize', call_info.call_sequence)
155
+ assert_equal(0, call_info.children.length)
156
+ end
157
+
158
+ # useless test: what does it test?
159
+ def test_thread_back_and_forth
160
+ result = nil
161
+ seconds = Benchmark.realtime do
162
+ result = RubyProf.profile do
163
+ a = Thread.new { 100_000.times { sleep 0 }}
164
+ b = Thread.new { 100_000.times { sleep 0 }}
165
+ a.join
166
+ b.join
167
+ end
168
+ end
169
+ methods = result.threads.map {|thread| thread.methods}
170
+ timings = methods.flatten.sort
171
+ assert(timings[-1].total_time < seconds)
172
+ end
173
+
174
+ # useless test: what does it test?
175
+ def test_thread
176
+ RubyProf.profile do
177
+ begin
178
+ Timeout::timeout(2) do
179
+ while true
180
+ next
181
+ end
182
+ end
183
+ rescue Timeout::Error
184
+ end
185
+ end
186
+ end
187
+ end
@@ -1,202 +1,202 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
-
6
- class UniqueCallPath
7
- def method_a(i)
8
- if i==1
9
- method_b
10
- else
11
- method_c
12
- end
13
- end
14
-
15
- def method_b
16
- method_c
17
- end
18
-
19
- def method_c
20
- end
21
-
22
- def method_k(i)
23
- method_a(i)
24
- end
25
- end
26
-
27
-
28
- # -- Tests ----
29
- class UniqueCallPathTest < TestCase
30
- def test_root_method
31
- unique_call_path = UniqueCallPath.new
32
-
33
- result = RubyProf.profile do
34
- unique_call_path.method_a(1)
35
- end
36
-
37
- root_methods = Array.new
38
- result.threads.each do |thread|
39
- thread.methods.each do | m |
40
- if m.root?
41
- root_methods.push(m)
42
- end
43
- end
44
- end
45
-
46
- assert_equal(1, root_methods.length)
47
- assert_equal("UniqueCallPathTest#test_root_method", root_methods[0].full_name)
48
- end
49
-
50
- def test_root_children
51
- unique_call_path = UniqueCallPath.new
52
-
53
- result = RubyProf.profile do
54
- unique_call_path.method_a(1)
55
- unique_call_path.method_k(2)
56
- end
57
-
58
- root_methods = Array.new
59
- result.threads.each do |thread|
60
- thread.methods.each do | m |
61
- if m.root?
62
- root_methods.push(m)
63
- end
64
- end
65
- end
66
-
67
- assert_equal(1, root_methods.length)
68
-
69
- root_children = Array.new
70
- root_methods[0].children.each do | c |
71
- if c.parent.target.eql?(root_methods[0])
72
- root_children.push(c)
73
- end
74
- end
75
-
76
- children = root_children.sort do |c1, c2|
77
- c1.target.full_name <=> c2.target.full_name
78
- end
79
-
80
- assert_equal(2, children.length)
81
- assert_equal("UniqueCallPath#method_a", children[0].target.full_name)
82
- assert_equal("UniqueCallPath#method_k", children[1].target.full_name)
83
- end
84
-
85
- def test_children_of
86
- unique_call_path = UniqueCallPath.new
87
-
88
- result = RubyProf.profile do
89
- unique_call_path.method_a(1)
90
- unique_call_path.method_k(2)
91
- end
92
-
93
- root_methods = Array.new
94
- result.threads.each do |thread|
95
- thread.methods.each do | m |
96
- if m.root?
97
- root_methods.push(m)
98
- end
99
- end
100
- end
101
-
102
- assert_equal(1, root_methods.length)
103
- method = root_methods[0]
104
- assert_equal('UniqueCallPathTest#test_children_of', method.full_name)
105
-
106
- call_info_a = nil
107
- root_methods[0].children.each do | c |
108
- if c.target.full_name == "UniqueCallPath#method_a"
109
- call_info_a = c
110
- break
111
- end
112
- end
113
-
114
- assert !call_info_a.nil?
115
-
116
- children_of_a = Array.new
117
-
118
- call_info_a.children.each do | c |
119
- if c.parent.eql?(call_info_a)
120
- children_of_a.push(c)
121
- end
122
- end
123
-
124
- assert_equal(2, call_info_a.target.children.length)
125
-
126
- children_of_a = children_of_a.sort do |c1, c2|
127
- c1.target.full_name <=> c2.target.full_name
128
- end
129
-
130
- assert_equal(1, children_of_a.length)
131
- assert_equal("UniqueCallPath#method_b", children_of_a[0].target.full_name)
132
- end
133
-
134
- def test_id2ref
135
- unique_call_path = UniqueCallPath.new
136
-
137
- result = RubyProf.profile do
138
- unique_call_path.method_a(1)
139
- end
140
-
141
- root_methods = Array.new
142
- result.threads.each do |thread|
143
- thread.methods.each do | m |
144
- if m.root?
145
- root_methods.push(m)
146
- end
147
- end
148
- end
149
-
150
- child = root_methods[0].children[0]
151
-
152
- refute_equal(0, child.object_id)
153
- #assert_equal(RubyProf::CallInfo.id2ref(child.id).target.full_name, child.target.full_name)
154
- end
155
-
156
- def test_unique_path
157
- unique_call_path = UniqueCallPath.new
158
-
159
- result = RubyProf.profile do
160
- unique_call_path.method_a(1)
161
- unique_call_path.method_k(1)
162
- end
163
-
164
- root_methods = Array.new
165
- result.threads.each do |thread|
166
- thread.methods.each do | m |
167
- if m.root?
168
- root_methods.push(m)
169
- end
170
- end
171
- end
172
-
173
- assert_equal(1, root_methods.length)
174
-
175
- call_info_a = nil
176
- root_methods[0].children.each do | c |
177
- if c.target.full_name == "UniqueCallPath#method_a"
178
- call_info_a = c
179
- break
180
- end
181
- end
182
-
183
- assert !call_info_a.nil?
184
-
185
- children_of_a = Array.new
186
- call_info_a.children.each do |c|
187
- if c.parent.eql?(call_info_a)
188
- children_of_a.push(c)
189
- end
190
- end
191
-
192
- assert_equal(2, call_info_a.target.children.length)
193
-
194
- children_of_a = children_of_a.sort do |c1, c2|
195
- c1.target.full_name <=> c2.target.full_name
196
- end
197
-
198
- assert_equal(1, children_of_a.length)
199
- assert_equal(1, children_of_a[0].called)
200
- assert_equal("UniqueCallPath#method_b", children_of_a[0].target.full_name)
201
- end
202
- end
1
+ #!/usr/bin/env ruby
2
+ # encoding: UTF-8
3
+
4
+ require File.expand_path('../test_helper', __FILE__)
5
+
6
+ class UniqueCallPath
7
+ def method_a(i)
8
+ if i==1
9
+ method_b
10
+ else
11
+ method_c
12
+ end
13
+ end
14
+
15
+ def method_b
16
+ method_c
17
+ end
18
+
19
+ def method_c
20
+ end
21
+
22
+ def method_k(i)
23
+ method_a(i)
24
+ end
25
+ end
26
+
27
+
28
+ # -- Tests ----
29
+ class UniqueCallPathTest < TestCase
30
+ def test_root_method
31
+ unique_call_path = UniqueCallPath.new
32
+
33
+ result = RubyProf.profile do
34
+ unique_call_path.method_a(1)
35
+ end
36
+
37
+ root_methods = Array.new
38
+ result.threads.each do |thread|
39
+ thread.methods.each do | m |
40
+ if m.root?
41
+ root_methods.push(m)
42
+ end
43
+ end
44
+ end
45
+
46
+ assert_equal(1, root_methods.length)
47
+ assert_equal("UniqueCallPathTest#test_root_method", root_methods[0].full_name)
48
+ end
49
+
50
+ def test_root_children
51
+ unique_call_path = UniqueCallPath.new
52
+
53
+ result = RubyProf.profile do
54
+ unique_call_path.method_a(1)
55
+ unique_call_path.method_k(2)
56
+ end
57
+
58
+ root_methods = Array.new
59
+ result.threads.each do |thread|
60
+ thread.methods.each do | m |
61
+ if m.root?
62
+ root_methods.push(m)
63
+ end
64
+ end
65
+ end
66
+
67
+ assert_equal(1, root_methods.length)
68
+
69
+ root_children = Array.new
70
+ root_methods[0].children.each do | c |
71
+ if c.parent.target.eql?(root_methods[0])
72
+ root_children.push(c)
73
+ end
74
+ end
75
+
76
+ children = root_children.sort do |c1, c2|
77
+ c1.target.full_name <=> c2.target.full_name
78
+ end
79
+
80
+ assert_equal(2, children.length)
81
+ assert_equal("UniqueCallPath#method_a", children[0].target.full_name)
82
+ assert_equal("UniqueCallPath#method_k", children[1].target.full_name)
83
+ end
84
+
85
+ def test_children_of
86
+ unique_call_path = UniqueCallPath.new
87
+
88
+ result = RubyProf.profile do
89
+ unique_call_path.method_a(1)
90
+ unique_call_path.method_k(2)
91
+ end
92
+
93
+ root_methods = Array.new
94
+ result.threads.each do |thread|
95
+ thread.methods.each do | m |
96
+ if m.root?
97
+ root_methods.push(m)
98
+ end
99
+ end
100
+ end
101
+
102
+ assert_equal(1, root_methods.length)
103
+ method = root_methods[0]
104
+ assert_equal('UniqueCallPathTest#test_children_of', method.full_name)
105
+
106
+ call_info_a = nil
107
+ root_methods[0].children.each do | c |
108
+ if c.target.full_name == "UniqueCallPath#method_a"
109
+ call_info_a = c
110
+ break
111
+ end
112
+ end
113
+
114
+ assert !call_info_a.nil?
115
+
116
+ children_of_a = Array.new
117
+
118
+ call_info_a.children.each do | c |
119
+ if c.parent.eql?(call_info_a)
120
+ children_of_a.push(c)
121
+ end
122
+ end
123
+
124
+ assert_equal(2, call_info_a.target.children.length)
125
+
126
+ children_of_a = children_of_a.sort do |c1, c2|
127
+ c1.target.full_name <=> c2.target.full_name
128
+ end
129
+
130
+ assert_equal(1, children_of_a.length)
131
+ assert_equal("UniqueCallPath#method_b", children_of_a[0].target.full_name)
132
+ end
133
+
134
+ def test_id2ref
135
+ unique_call_path = UniqueCallPath.new
136
+
137
+ result = RubyProf.profile do
138
+ unique_call_path.method_a(1)
139
+ end
140
+
141
+ root_methods = Array.new
142
+ result.threads.each do |thread|
143
+ thread.methods.each do | m |
144
+ if m.root?
145
+ root_methods.push(m)
146
+ end
147
+ end
148
+ end
149
+
150
+ child = root_methods[0].children[0]
151
+
152
+ refute_equal(0, child.object_id)
153
+ #assert_equal(RubyProf::CallInfo.id2ref(child.id).target.full_name, child.target.full_name)
154
+ end
155
+
156
+ def test_unique_path
157
+ unique_call_path = UniqueCallPath.new
158
+
159
+ result = RubyProf.profile do
160
+ unique_call_path.method_a(1)
161
+ unique_call_path.method_k(1)
162
+ end
163
+
164
+ root_methods = Array.new
165
+ result.threads.each do |thread|
166
+ thread.methods.each do | m |
167
+ if m.root?
168
+ root_methods.push(m)
169
+ end
170
+ end
171
+ end
172
+
173
+ assert_equal(1, root_methods.length)
174
+
175
+ call_info_a = nil
176
+ root_methods[0].children.each do | c |
177
+ if c.target.full_name == "UniqueCallPath#method_a"
178
+ call_info_a = c
179
+ break
180
+ end
181
+ end
182
+
183
+ assert !call_info_a.nil?
184
+
185
+ children_of_a = Array.new
186
+ call_info_a.children.each do |c|
187
+ if c.parent.eql?(call_info_a)
188
+ children_of_a.push(c)
189
+ end
190
+ end
191
+
192
+ assert_equal(2, call_info_a.target.children.length)
193
+
194
+ children_of_a = children_of_a.sort do |c1, c2|
195
+ c1.target.full_name <=> c2.target.full_name
196
+ end
197
+
198
+ assert_equal(1, children_of_a.length)
199
+ assert_equal(1, children_of_a[0].called)
200
+ assert_equal("UniqueCallPath#method_b", children_of_a[0].target.full_name)
201
+ end
202
+ end