ruby-prof 0.18.0 → 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (112) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGES +23 -0
  3. data/LICENSE +2 -2
  4. data/README.rdoc +1 -483
  5. data/Rakefile +3 -6
  6. data/bin/ruby-prof +65 -30
  7. data/ext/ruby_prof/extconf.rb +6 -38
  8. data/ext/ruby_prof/rp_allocation.c +292 -0
  9. data/ext/ruby_prof/rp_allocation.h +31 -0
  10. data/ext/ruby_prof/rp_call_info.c +137 -279
  11. data/ext/ruby_prof/rp_call_info.h +16 -34
  12. data/ext/ruby_prof/rp_measure_allocations.c +25 -49
  13. data/ext/ruby_prof/rp_measure_memory.c +21 -56
  14. data/ext/ruby_prof/rp_measure_process_time.c +28 -36
  15. data/ext/ruby_prof/rp_measure_wall_time.c +36 -19
  16. data/ext/ruby_prof/rp_measurement.c +236 -0
  17. data/ext/ruby_prof/rp_measurement.h +49 -0
  18. data/ext/ruby_prof/rp_method.c +395 -383
  19. data/ext/ruby_prof/rp_method.h +34 -39
  20. data/ext/ruby_prof/rp_profile.c +881 -0
  21. data/ext/ruby_prof/rp_profile.h +36 -0
  22. data/ext/ruby_prof/rp_stack.c +103 -80
  23. data/ext/ruby_prof/rp_stack.h +5 -12
  24. data/ext/ruby_prof/rp_thread.c +149 -88
  25. data/ext/ruby_prof/rp_thread.h +15 -6
  26. data/ext/ruby_prof/ruby_prof.c +11 -757
  27. data/ext/ruby_prof/ruby_prof.h +4 -47
  28. data/ext/ruby_prof/vc/ruby_prof.vcxproj +10 -8
  29. data/lib/ruby-prof.rb +2 -17
  30. data/lib/ruby-prof/assets/graph_printer.html.erb +356 -0
  31. data/lib/ruby-prof/call_info.rb +35 -93
  32. data/lib/ruby-prof/call_info_visitor.rb +19 -21
  33. data/lib/ruby-prof/compatibility.rb +37 -107
  34. data/lib/ruby-prof/exclude_common_methods.rb +198 -0
  35. data/lib/ruby-prof/measurement.rb +14 -0
  36. data/lib/ruby-prof/method_info.rb +52 -83
  37. data/lib/ruby-prof/printers/abstract_printer.rb +66 -52
  38. data/lib/ruby-prof/printers/call_info_printer.rb +13 -3
  39. data/lib/ruby-prof/printers/call_stack_printer.rb +32 -28
  40. data/lib/ruby-prof/printers/call_tree_printer.rb +20 -12
  41. data/lib/ruby-prof/printers/dot_printer.rb +5 -5
  42. data/lib/ruby-prof/printers/flat_printer.rb +6 -24
  43. data/lib/ruby-prof/printers/graph_html_printer.rb +7 -192
  44. data/lib/ruby-prof/printers/graph_printer.rb +13 -15
  45. data/lib/ruby-prof/printers/multi_printer.rb +66 -23
  46. data/lib/ruby-prof/profile.rb +10 -3
  47. data/lib/ruby-prof/rack.rb +0 -3
  48. data/lib/ruby-prof/thread.rb +12 -12
  49. data/lib/ruby-prof/version.rb +1 -1
  50. data/ruby-prof.gemspec +2 -2
  51. data/test/abstract_printer_test.rb +0 -27
  52. data/test/alias_test.rb +129 -0
  53. data/test/basic_test.rb +41 -40
  54. data/test/call_info_visitor_test.rb +3 -3
  55. data/test/dynamic_method_test.rb +0 -2
  56. data/test/line_number_test.rb +120 -39
  57. data/test/marshal_test.rb +119 -0
  58. data/test/measure_allocations.rb +30 -0
  59. data/test/measure_allocations_test.rb +371 -12
  60. data/test/measure_allocations_trace_test.rb +385 -0
  61. data/test/measure_memory_trace_test.rb +756 -0
  62. data/test/measure_process_time_test.rb +821 -33
  63. data/test/measure_times.rb +54 -0
  64. data/test/measure_wall_time_test.rb +349 -145
  65. data/test/multi_printer_test.rb +1 -34
  66. data/test/parser_timings.rb +24 -0
  67. data/test/pause_resume_test.rb +5 -5
  68. data/test/prime.rb +2 -0
  69. data/test/printer_call_tree_test.rb +31 -0
  70. data/test/printer_flat_test.rb +68 -0
  71. data/test/printer_graph_html_test.rb +60 -0
  72. data/test/printer_graph_test.rb +41 -0
  73. data/test/printers_test.rb +32 -166
  74. data/test/printing_recursive_graph_test.rb +26 -72
  75. data/test/recursive_test.rb +72 -77
  76. data/test/stack_printer_test.rb +2 -15
  77. data/test/start_stop_test.rb +22 -25
  78. data/test/test_helper.rb +5 -248
  79. data/test/thread_test.rb +11 -54
  80. data/test/unique_call_path_test.rb +16 -28
  81. data/test/yarv_test.rb +1 -0
  82. metadata +24 -34
  83. data/examples/flat.txt +0 -50
  84. data/examples/graph.dot +0 -84
  85. data/examples/graph.html +0 -823
  86. data/examples/graph.txt +0 -139
  87. data/examples/multi.flat.txt +0 -23
  88. data/examples/multi.graph.html +0 -760
  89. data/examples/multi.grind.dat +0 -114
  90. data/examples/multi.stack.html +0 -547
  91. data/examples/stack.html +0 -547
  92. data/ext/ruby_prof/rp_measure.c +0 -40
  93. data/ext/ruby_prof/rp_measure.h +0 -45
  94. data/ext/ruby_prof/rp_measure_cpu_time.c +0 -136
  95. data/ext/ruby_prof/rp_measure_gc_runs.c +0 -73
  96. data/ext/ruby_prof/rp_measure_gc_time.c +0 -60
  97. data/lib/ruby-prof/aggregate_call_info.rb +0 -76
  98. data/lib/ruby-prof/printers/flat_printer_with_line_numbers.rb +0 -83
  99. data/lib/ruby-prof/profile/exclude_common_methods.rb +0 -207
  100. data/lib/ruby-prof/profile/legacy_method_elimination.rb +0 -50
  101. data/test/aggregate_test.rb +0 -136
  102. data/test/block_test.rb +0 -74
  103. data/test/call_info_test.rb +0 -78
  104. data/test/fiber_test.rb +0 -79
  105. data/test/issue137_test.rb +0 -63
  106. data/test/measure_cpu_time_test.rb +0 -212
  107. data/test/measure_gc_runs_test.rb +0 -32
  108. data/test/measure_gc_time_test.rb +0 -36
  109. data/test/measure_memory_test.rb +0 -33
  110. data/test/method_elimination_test.rb +0 -84
  111. data/test/module_test.rb +0 -45
  112. data/test/stack_test.rb +0 -138
@@ -1,36 +0,0 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
-
6
- class MeasureGCTimeTest < TestCase
7
- include MemoryTestHelper
8
-
9
- def test_gc_time_mode
10
- RubyProf::measure_mode = RubyProf::GC_TIME
11
- assert_equal(RubyProf::GC_TIME, RubyProf::measure_mode)
12
- end
13
-
14
- def test_gc_time_enabled_defined
15
- assert(defined?(RubyProf::GC_TIME_ENABLED))
16
- end
17
-
18
- if RubyProf::GC_TIME_ENABLED
19
- def test_gc_time
20
- RubyProf::measure_mode = RubyProf::GC_TIME
21
- RubyProf.enable_gc_stats_if_needed
22
-
23
- t = RubyProf.measure_gc_time
24
- assert_kind_of Float, t
25
-
26
- GC.start
27
-
28
- u = RubyProf.measure_gc_time
29
- assert u > t, [t, u].inspect
30
-
31
- memory_test_helper
32
- ensure
33
- RubyProf.disable_gc_stats_if_needed
34
- end
35
- end
36
- end
@@ -1,33 +0,0 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
-
6
- class MeasureMemoryTest < TestCase
7
- include MemoryTestHelper
8
-
9
- def test_memory_mode
10
- RubyProf::measure_mode = RubyProf::MEMORY
11
- assert_equal(RubyProf::MEMORY, RubyProf::measure_mode)
12
- end
13
-
14
- def test_memory_enabled_defined
15
- assert(defined?(RubyProf::MEMORY_ENABLED))
16
- end
17
-
18
- if RubyProf::MEMORY_ENABLED
19
- def test_memory
20
- RubyProf::measure_mode = RubyProf::MEMORY
21
- RubyProf.enable_gc_stats_if_needed
22
- t = RubyProf.measure_memory
23
- assert_kind_of Float, t
24
- u = RubyProf.measure_memory
25
- assert_operator u, :>, t
26
- total = memory_test_helper
27
- assert(total > 0, 'Should measure more than zero kilobytes of memory usage')
28
- refute_equal(0, total % 1, 'Should not truncate fractional kilobyte measurements')
29
- ensure
30
- RubyProf.disable_gc_stats_if_needed
31
- end
32
- end
33
- end
@@ -1,84 +0,0 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
-
6
- # Test data
7
- # A
8
- # / \
9
- # B C
10
- # \
11
- # B
12
-
13
- module MethodElimination
14
- def self.a
15
- 1.times {|i| c}
16
- end
17
-
18
- def self.b
19
- sleep 0.1
20
- end
21
-
22
- def self.c
23
- 1.times {|i| b}
24
- end
25
- end
26
-
27
- class MethodEliminationTest < TestCase
28
- def setup
29
- # Need to use wall time for this test due to the sleep calls
30
- RubyProf::measure_mode = RubyProf::WALL_TIME
31
- end
32
-
33
- def test_setting_parent
34
- result = RubyProf.profile do
35
- 1000.times { 1+1 }
36
- end
37
- method_infos = result.threads.first.methods.sort.reverse
38
- assert(m1 = method_infos[0])
39
- assert(c1 = m1.call_infos.first)
40
- assert_nil(c1.parent)
41
- end
42
-
43
- def test_methods_can_be_eliminated
44
- RubyProf.start
45
- 5.times {MethodElimination.a}
46
- result = RubyProf.stop
47
-
48
- methods = result.threads.first.methods.sort.reverse
49
-
50
- assert_equal(6, methods.count)
51
- assert_equal('MethodEliminationTest#test_methods_can_be_eliminated', methods[0].full_name)
52
- assert_equal('Integer#times', methods[1].full_name)
53
- assert_equal('<Module::MethodElimination>#a', methods[2].full_name)
54
- assert_equal('<Module::MethodElimination>#c', methods[3].full_name)
55
- assert_equal('<Module::MethodElimination>#b', methods[4].full_name)
56
- assert_equal('Kernel#sleep', methods[5].full_name)
57
-
58
- result.eliminate_methods!([/Integer#times/])
59
-
60
- methods = result.threads.first.methods.sort.reverse
61
- assert_equal(5, methods.count)
62
- assert_equal('MethodEliminationTest#test_methods_can_be_eliminated', methods[0].full_name)
63
- assert_equal('<Module::MethodElimination>#a', methods[1].full_name)
64
- assert_equal('<Module::MethodElimination>#c', methods[2].full_name)
65
- assert_equal('<Module::MethodElimination>#b', methods[3].full_name)
66
- assert_equal('Kernel#sleep', methods[4].full_name)
67
- end
68
-
69
- private
70
-
71
- def assert_method_has_been_eliminated(result, eliminated_method)
72
- result.threads.each do |thread|
73
- thread.methods.each do |method|
74
- method.call_infos.each do |ci|
75
- assert(ci.target != eliminated_method, "broken self")
76
- assert(ci.parent.target != eliminated_method, "broken parent") if ci.parent
77
- ci.children.each do |callee|
78
- assert(callee.target != eliminated_method, "broken kid")
79
- end
80
- end
81
- end
82
- end
83
- end
84
- end
@@ -1,45 +0,0 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
-
6
- # Need to use wall time for this test due to the sleep calls
7
- RubyProf::measure_mode = RubyProf::WALL_TIME
8
-
9
- module Foo
10
- def Foo::hello
11
- sleep(0.5)
12
- end
13
- end
14
-
15
- module Bar
16
- def Bar::hello
17
- sleep(0.5)
18
- Foo::hello
19
- end
20
-
21
- def hello
22
- sleep(0.5)
23
- Bar::hello
24
- end
25
- end
26
-
27
- include Bar
28
-
29
- class ModuleTest < TestCase
30
- def test_nested_modules
31
- result = RubyProf.profile do
32
- hello
33
- end
34
-
35
- methods = result.threads.first.methods
36
-
37
- # Length should be 5
38
- assert_equal(5, methods.length)
39
-
40
- # these methods should be in there... (hard to tell order though).
41
- for name in ['ModuleTest#test_nested_modules','Bar#hello','Kernel#sleep','<Module::Bar>#hello','<Module::Foo>#hello']
42
- assert methods.map(&:full_name).include?( name )
43
- end
44
- end
45
- end
@@ -1,138 +0,0 @@
1
- #!/usr/bin/env ruby
2
- # encoding: UTF-8
3
-
4
- require File.expand_path('../test_helper', __FILE__)
5
-
6
- # Test data
7
- # A
8
- # / \
9
- # B C
10
- # \
11
- # B
12
-
13
- class StackClass
14
- def a
15
- sleep 1
16
- b
17
- c
18
- end
19
-
20
- def b
21
- sleep 2
22
- end
23
-
24
- def c
25
- sleep 3
26
- b
27
- end
28
- end
29
-
30
- class StackTest < TestCase
31
- def setup
32
- # Need to use wall time for this test due to the sleep calls
33
- RubyProf::measure_mode = RubyProf::WALL_TIME
34
- end
35
-
36
- def test_call_sequence
37
- c = StackClass.new
38
- result = RubyProf.profile do
39
- c.a
40
- end
41
-
42
- # Length should be 5:
43
- # StackTest#test_call_sequence
44
- # StackClass#a
45
- # Kernel#sleep
46
- # StackClass#c
47
- # StackClass#b
48
-
49
- methods = result.threads.first.methods.sort.reverse
50
- assert_equal(5, methods.length)
51
-
52
- # Check StackTest#test_call_sequence
53
- method = methods[0]
54
- assert_equal('StackTest#test_call_sequence', method.full_name)
55
- assert_equal(1, method.called)
56
- assert_in_delta(8, method.total_time, 0.25)
57
- assert_in_delta(0, method.wait_time, 0.01)
58
- assert_in_delta(0, method.self_time, 0.01)
59
- assert_in_delta(8, method.children_time, 0.25)
60
- assert_equal(1, method.call_infos.length)
61
-
62
- call_info = method.call_infos[0]
63
- assert_equal('StackTest#test_call_sequence', call_info.call_sequence)
64
- assert_equal(1, call_info.children.length)
65
-
66
- # Check StackClass#a
67
- method = methods[1]
68
- assert_equal('StackClass#a', method.full_name)
69
- assert_equal(1, method.called)
70
- assert_in_delta(8, method.total_time, 0.15)
71
- assert_in_delta(0, method.wait_time, 0.01)
72
- assert_in_delta(0, method.self_time, 0.01)
73
- assert_in_delta(8, method.children_time, 0.05)
74
- assert_equal(1, method.call_infos.length)
75
-
76
- call_info = method.call_infos[0]
77
- assert_equal('StackTest#test_call_sequence->StackClass#a', call_info.call_sequence)
78
- assert_equal(3, call_info.children.length)
79
-
80
- # Check Kernel#sleep
81
- method = methods[2]
82
- assert_equal('Kernel#sleep', method.full_name)
83
- assert_equal(4, method.called)
84
- assert_in_delta(8, method.total_time, 0.05)
85
- assert_in_delta(0, method.wait_time, 0.01)
86
- assert_in_delta(8, method.self_time, 0.05)
87
- assert_in_delta(0, method.children_time, 0.05)
88
- assert_equal(4, method.call_infos.length)
89
-
90
- call_info = method.call_infos[0]
91
- assert_equal('StackTest#test_call_sequence->StackClass#a->Kernel#sleep', call_info.call_sequence)
92
- assert_equal(0, call_info.children.length)
93
-
94
- call_info = method.call_infos[1]
95
- assert_equal('StackTest#test_call_sequence->StackClass#a->StackClass#b->Kernel#sleep', call_info.call_sequence)
96
- assert_equal(0, call_info.children.length)
97
-
98
- call_info = method.call_infos[2]
99
- assert_equal('StackTest#test_call_sequence->StackClass#a->StackClass#c->Kernel#sleep', call_info.call_sequence)
100
- assert_equal(0, call_info.children.length)
101
-
102
- call_info = method.call_infos[3]
103
- assert_equal('StackTest#test_call_sequence->StackClass#a->StackClass#c->StackClass#b->Kernel#sleep', call_info.call_sequence)
104
- assert_equal(0, call_info.children.length)
105
-
106
- # Check StackClass#c
107
- method = methods[3]
108
- assert_equal('StackClass#c', method.full_name)
109
- assert_equal(1, method.called)
110
- assert_in_delta(5, method.total_time, 0.05)
111
- assert_in_delta(0, method.wait_time, 0.01)
112
- assert_in_delta(0, method.self_time, 0.01)
113
- assert_in_delta(5, method.children_time, 0.05)
114
- assert_equal(1, method.call_infos.length)
115
-
116
- call_info = method.call_infos[0]
117
- assert_equal('StackTest#test_call_sequence->StackClass#a->StackClass#c', call_info.call_sequence)
118
- assert_equal(2, call_info.children.length)
119
-
120
- # Check StackClass#b
121
- method = methods[4]
122
- assert_equal('StackClass#b', method.full_name)
123
- assert_equal(2, method.called)
124
- assert_in_delta(4, method.total_time, 0.05)
125
- assert_in_delta(0, method.wait_time, 0.01)
126
- assert_in_delta(0, method.self_time, 0.01)
127
- assert_in_delta(4, method.children_time, 0.05)
128
- assert_equal(2, method.call_infos.length)
129
-
130
- call_info = method.call_infos[0]
131
- assert_equal('StackTest#test_call_sequence->StackClass#a->StackClass#b', call_info.call_sequence)
132
- assert_equal(1, call_info.children.length)
133
-
134
- call_info = method.call_infos[1]
135
- assert_equal('StackTest#test_call_sequence->StackClass#a->StackClass#c->StackClass#b', call_info.call_sequence)
136
- assert_equal(1, call_info.children.length)
137
- end
138
- end