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.
- checksums.yaml +5 -5
- data/CHANGES +532 -467
- data/LICENSE +24 -24
- data/README.rdoc +5 -454
- data/Rakefile +110 -113
- data/bin/ruby-prof +380 -340
- data/bin/ruby-prof-check-trace +45 -45
- data/ext/ruby_prof/extconf.rb +36 -64
- data/ext/ruby_prof/rp_allocation.c +279 -0
- data/ext/ruby_prof/rp_allocation.h +31 -0
- data/ext/ruby_prof/rp_call_info.c +271 -407
- data/ext/ruby_prof/rp_call_info.h +35 -48
- data/ext/ruby_prof/rp_measure_allocations.c +52 -76
- data/ext/ruby_prof/rp_measure_memory.c +42 -77
- data/ext/ruby_prof/rp_measure_process_time.c +67 -71
- data/ext/ruby_prof/rp_measure_wall_time.c +62 -45
- data/ext/ruby_prof/rp_measurement.c +230 -0
- data/ext/ruby_prof/rp_measurement.h +50 -0
- data/ext/ruby_prof/rp_method.c +630 -411
- data/ext/ruby_prof/rp_method.h +70 -52
- data/ext/ruby_prof/rp_profile.c +895 -0
- data/ext/ruby_prof/rp_profile.h +37 -0
- data/ext/ruby_prof/rp_stack.c +196 -128
- data/ext/ruby_prof/rp_stack.h +56 -51
- data/ext/ruby_prof/rp_thread.c +337 -273
- data/ext/ruby_prof/rp_thread.h +36 -27
- data/ext/ruby_prof/ruby_prof.c +48 -671
- data/ext/ruby_prof/ruby_prof.h +17 -56
- data/ext/ruby_prof/vc/ruby_prof.sln +20 -21
- data/ext/ruby_prof/vc/{ruby_prof_20.vcxproj → ruby_prof.vcxproj} +38 -5
- data/lib/ruby-prof.rb +52 -58
- data/lib/ruby-prof/assets/call_stack_printer.html.erb +713 -0
- data/lib/ruby-prof/assets/call_stack_printer.png +0 -0
- data/lib/ruby-prof/assets/graph_printer.html.erb +356 -0
- data/lib/ruby-prof/call_info.rb +57 -126
- data/lib/ruby-prof/call_info_visitor.rb +38 -40
- data/lib/ruby-prof/compatibility.rb +109 -178
- data/lib/ruby-prof/exclude_common_methods.rb +198 -0
- data/lib/ruby-prof/measurement.rb +14 -0
- data/lib/ruby-prof/method_info.rb +90 -129
- data/lib/ruby-prof/printers/abstract_printer.rb +127 -85
- data/lib/ruby-prof/printers/call_info_printer.rb +51 -41
- data/lib/ruby-prof/printers/call_stack_printer.rb +182 -260
- data/lib/ruby-prof/printers/call_tree_printer.rb +151 -130
- data/lib/ruby-prof/printers/dot_printer.rb +132 -132
- data/lib/ruby-prof/printers/flat_printer.rb +52 -70
- data/lib/ruby-prof/printers/graph_html_printer.rb +63 -244
- data/lib/ruby-prof/printers/graph_printer.rb +114 -116
- data/lib/ruby-prof/printers/multi_printer.rb +127 -58
- data/lib/ruby-prof/profile.rb +33 -55
- data/lib/ruby-prof/rack.rb +171 -95
- data/lib/ruby-prof/task.rb +147 -147
- data/lib/ruby-prof/thread.rb +35 -41
- data/lib/ruby-prof/version.rb +3 -3
- data/lib/unprof.rb +10 -10
- data/ruby-prof.gemspec +58 -57
- data/test/abstract_printer_test.rb +26 -0
- data/test/alias_test.rb +129 -0
- data/test/basic_test.rb +129 -128
- data/test/call_info_visitor_test.rb +31 -31
- data/test/duplicate_names_test.rb +32 -32
- data/test/dynamic_method_test.rb +53 -55
- data/test/enumerable_test.rb +21 -21
- data/test/exceptions_test.rb +24 -16
- data/test/exclude_methods_test.rb +146 -0
- data/test/exclude_threads_test.rb +53 -53
- data/test/fiber_test.rb +73 -79
- data/test/gc_test.rb +96 -0
- data/test/line_number_test.rb +161 -71
- data/test/marshal_test.rb +119 -0
- data/test/measure_allocations.rb +30 -0
- data/test/measure_allocations_test.rb +385 -26
- data/test/measure_allocations_trace_test.rb +385 -0
- data/test/measure_memory_trace_test.rb +756 -0
- data/test/measure_process_time_test.rb +849 -63
- data/test/measure_times.rb +54 -0
- data/test/measure_wall_time_test.rb +459 -255
- data/test/multi_printer_test.rb +71 -83
- data/test/no_method_class_test.rb +15 -15
- data/test/parser_timings.rb +24 -0
- data/test/pause_resume_test.rb +166 -166
- data/test/prime.rb +56 -54
- data/test/printer_call_stack_test.rb +28 -0
- data/test/printer_call_tree_test.rb +31 -0
- data/test/printer_flat_test.rb +68 -0
- data/test/printer_graph_html_test.rb +60 -0
- data/test/printer_graph_test.rb +41 -0
- data/test/printers_test.rb +141 -255
- data/test/printing_recursive_graph_test.rb +81 -127
- data/test/rack_test.rb +157 -93
- data/test/recursive_test.rb +210 -215
- data/test/singleton_test.rb +38 -38
- data/test/stack_printer_test.rb +64 -78
- data/test/start_stop_test.rb +109 -112
- data/test/test_helper.rb +24 -264
- data/test/thread_test.rb +144 -187
- data/test/unique_call_path_test.rb +190 -202
- data/test/yarv_test.rb +56 -55
- metadata +34 -114
- data/doc/LICENSE.html +0 -114
- data/doc/README_rdoc.html +0 -603
- data/doc/Rack.html +0 -95
- data/doc/Rack/RubyProf.html +0 -226
- data/doc/RubyProf.html +0 -962
- data/doc/RubyProf/AbstractPrinter.html +0 -546
- data/doc/RubyProf/AggregateCallInfo.html +0 -551
- data/doc/RubyProf/CallInfo.html +0 -639
- data/doc/RubyProf/CallInfoPrinter.html +0 -120
- data/doc/RubyProf/CallInfoVisitor.html +0 -198
- data/doc/RubyProf/CallStackPrinter.html +0 -1121
- data/doc/RubyProf/CallTreePrinter.html +0 -641
- data/doc/RubyProf/Cmd.html +0 -631
- data/doc/RubyProf/DotPrinter.html +0 -257
- data/doc/RubyProf/FlatPrinter.html +0 -163
- data/doc/RubyProf/FlatPrinterWithLineNumbers.html +0 -208
- data/doc/RubyProf/GraphHtmlPrinter.html +0 -552
- data/doc/RubyProf/GraphPrinter.html +0 -139
- data/doc/RubyProf/MethodInfo.html +0 -745
- data/doc/RubyProf/MultiPrinter.html +0 -360
- data/doc/RubyProf/Profile.html +0 -763
- data/doc/RubyProf/ProfileTask.html +0 -490
- data/doc/RubyProf/Thread.html +0 -310
- data/doc/created.rid +0 -31
- data/doc/css/fonts.css +0 -167
- data/doc/css/rdoc.css +0 -590
- data/doc/examples/flat_txt.html +0 -138
- data/doc/examples/graph_html.html +0 -909
- data/doc/examples/graph_txt.html +0 -247
- data/doc/fonts/Lato-Light.ttf +0 -0
- data/doc/fonts/Lato-LightItalic.ttf +0 -0
- data/doc/fonts/Lato-Regular.ttf +0 -0
- data/doc/fonts/Lato-RegularItalic.ttf +0 -0
- data/doc/fonts/SourceCodePro-Bold.ttf +0 -0
- data/doc/fonts/SourceCodePro-Regular.ttf +0 -0
- data/doc/images/add.png +0 -0
- data/doc/images/arrow_up.png +0 -0
- data/doc/images/brick.png +0 -0
- data/doc/images/brick_link.png +0 -0
- data/doc/images/bug.png +0 -0
- data/doc/images/bullet_black.png +0 -0
- data/doc/images/bullet_toggle_minus.png +0 -0
- data/doc/images/bullet_toggle_plus.png +0 -0
- data/doc/images/date.png +0 -0
- data/doc/images/delete.png +0 -0
- data/doc/images/find.png +0 -0
- data/doc/images/loadingAnimation.gif +0 -0
- data/doc/images/macFFBgHack.png +0 -0
- data/doc/images/package.png +0 -0
- data/doc/images/page_green.png +0 -0
- data/doc/images/page_white_text.png +0 -0
- data/doc/images/page_white_width.png +0 -0
- data/doc/images/plugin.png +0 -0
- data/doc/images/ruby.png +0 -0
- data/doc/images/tag_blue.png +0 -0
- data/doc/images/tag_green.png +0 -0
- data/doc/images/transparent.png +0 -0
- data/doc/images/wrench.png +0 -0
- data/doc/images/wrench_orange.png +0 -0
- data/doc/images/zoom.png +0 -0
- data/doc/index.html +0 -626
- data/doc/js/darkfish.js +0 -161
- data/doc/js/jquery.js +0 -4
- data/doc/js/navigation.js +0 -142
- data/doc/js/navigation.js.gz +0 -0
- data/doc/js/search.js +0 -109
- data/doc/js/search_index.js +0 -1
- data/doc/js/search_index.js.gz +0 -0
- data/doc/js/searcher.js +0 -228
- data/doc/js/searcher.js.gz +0 -0
- data/doc/table_of_contents.html +0 -942
- data/examples/cachegrind.out.1 +0 -114
- data/examples/cachegrind.out.1.32313213 +0 -114
- data/examples/flat.txt +0 -50
- data/examples/graph.dot +0 -84
- data/examples/graph.html +0 -823
- data/examples/graph.txt +0 -139
- data/examples/multi.flat.txt +0 -23
- data/examples/multi.graph.html +0 -760
- data/examples/multi.grind.dat +0 -114
- data/examples/multi.stack.html +0 -547
- data/examples/stack.html +0 -547
- data/ext/ruby_prof/rp_measure.c +0 -40
- data/ext/ruby_prof/rp_measure.h +0 -45
- data/ext/ruby_prof/rp_measure_cpu_time.c +0 -136
- data/ext/ruby_prof/rp_measure_gc_runs.c +0 -73
- data/ext/ruby_prof/rp_measure_gc_time.c +0 -60
- data/ext/ruby_prof/vc/ruby_prof_18.vcxproj +0 -108
- data/ext/ruby_prof/vc/ruby_prof_19.vcxproj +0 -110
- data/lib/ruby-prof/aggregate_call_info.rb +0 -76
- data/lib/ruby-prof/assets/call_stack_printer.css.html +0 -117
- data/lib/ruby-prof/assets/call_stack_printer.js.html +0 -385
- data/lib/ruby-prof/printers/flat_printer_with_line_numbers.rb +0 -64
- data/test/aggregate_test.rb +0 -136
- data/test/block_test.rb +0 -74
- data/test/call_info_test.rb +0 -78
- data/test/issue137_test.rb +0 -63
- data/test/measure_cpu_time_test.rb +0 -213
- data/test/measure_gc_runs_test.rb +0 -32
- data/test/measure_gc_time_test.rb +0 -36
- data/test/measure_memory_test.rb +0 -33
- data/test/method_elimination_test.rb +0 -84
- data/test/module_test.rb +0 -45
- data/test/stack_test.rb +0 -138
| @@ -1,127 +1,81 @@ | |
| 1 | 
            -
            #!/usr/bin/env ruby
         | 
| 2 | 
            -
            # encoding: UTF-8
         | 
| 3 | 
            -
             | 
| 4 | 
            -
            require File.expand_path('../test_helper', __FILE__)
         | 
| 5 | 
            -
            require 'stringio'
         | 
| 6 | 
            -
            require 'fileutils'
         | 
| 7 | 
            -
             | 
| 8 | 
            -
            # --- code to be tested ---
         | 
| 9 | 
            -
            module PRGT
         | 
| 10 | 
            -
              extend self
         | 
| 11 | 
            -
             | 
| 12 | 
            -
              def f(n)
         | 
| 13 | 
            -
                n.times { sleep 0.1 }
         | 
| 14 | 
            -
              end
         | 
| 15 | 
            -
             | 
| 16 | 
            -
              def g(n)
         | 
| 17 | 
            -
                n.times { sleep 0.2 }
         | 
| 18 | 
            -
              end
         | 
| 19 | 
            -
             | 
| 20 | 
            -
              def run
         | 
| 21 | 
            -
                2.times { f(2); g(4) }
         | 
| 22 | 
            -
              end
         | 
| 23 | 
            -
            end
         | 
| 24 | 
            -
             | 
| 25 | 
            -
            # --- expected test output ---
         | 
| 26 | 
            -
            =begin
         | 
| 27 | 
            -
            Measure Mode: wall_time
         | 
| 28 | 
            -
            Thread ID:  | 
| 29 | 
            -
            Fiber ID:  | 
| 30 | 
            -
            Total Time: 2. | 
| 31 | 
            -
            Sort by: | 
| 32 | 
            -
             | 
| 33 | 
            -
              %total   %self      total       self       wait      child            calls | 
| 34 | 
            -
            --------------------------------------------------------------------------------
         | 
| 35 | 
            -
             | 
| 36 | 
            -
             | 
| 37 | 
            -
             | 
| 38 | 
            -
             | 
| 39 | 
            -
             | 
| 40 | 
            -
             | 
| 41 | 
            -
            --------------------------------------------------------------------------------
         | 
| 42 | 
            -
                                  0. | 
| 43 | 
            -
             | 
| 44 | 
            -
                                   | 
| 45 | 
            -
             | 
| 46 | 
            -
                                   | 
| 47 | 
            -
                                  1. | 
| 48 | 
            -
                                   | 
| 49 | 
            -
             | 
| 50 | 
            -
                                  2. | 
| 51 | 
            -
             | 
| 52 | 
            -
             | 
| 53 | 
            -
             | 
| 54 | 
            -
             | 
| 55 | 
            -
             | 
| 56 | 
            -
             | 
| 57 | 
            -
             | 
| 58 | 
            -
             | 
| 59 | 
            -
                                   | 
| 60 | 
            -
             | 
| 61 | 
            -
            * indicates recursively called methods
         | 
| 62 | 
            -
            =end
         | 
| 63 | 
            -
             | 
| 64 | 
            -
            class PrintingRecursiveGraphTest < TestCase
         | 
| 65 | 
            -
               | 
| 66 | 
            -
             | 
| 67 | 
            -
             | 
| 68 | 
            -
                 | 
| 69 | 
            -
             | 
| 70 | 
            -
                 | 
| 71 | 
            -
             | 
| 72 | 
            -
             | 
| 73 | 
            -
               | 
| 74 | 
            -
             | 
| 75 | 
            -
             | 
| 76 | 
            -
                printer | 
| 77 | 
            -
             | 
| 78 | 
            -
             | 
| 79 | 
            -
                 | 
| 80 | 
            -
             | 
| 81 | 
            -
             | 
| 82 | 
            -
             | 
| 83 | 
            -
                parsed_output = MetricsArray.parse(buffer)
         | 
| 84 | 
            -
             | 
| 85 | 
            -
                assert( integer_times  = parsed_output.metrics_for("*Integer#times") )
         | 
| 86 | 
            -
             | 
| 87 | 
            -
                actual_parents = integer_times.parents.map(&:name)
         | 
| 88 | 
            -
                expected_parents = %w(PRGT#f PRGT#g PRGT#run)
         | 
| 89 | 
            -
                assert_equal expected_parents, actual_parents
         | 
| 90 | 
            -
             | 
| 91 | 
            -
                actual_children = integer_times.children.map(&:name)
         | 
| 92 | 
            -
                expected_children = %w(Kernel#sleep PRGT#g PRGT#f)
         | 
| 93 | 
            -
                assert_equal expected_children, actual_children
         | 
| 94 | 
            -
             | 
| 95 | 
            -
                assert( fp = integer_times.parent("PRGT#f") )
         | 
| 96 | 
            -
                assert_in_delta(fp.total, fp.child, 0.01)
         | 
| 97 | 
            -
                assert_equal("2/5", fp.calls)
         | 
| 98 | 
            -
             | 
| 99 | 
            -
                assert( gp = integer_times.parent("PRGT#g") )
         | 
| 100 | 
            -
                assert_in_delta(gp.total, gp.child, 0.01)
         | 
| 101 | 
            -
                assert_equal("2/5", gp.calls)
         | 
| 102 | 
            -
             | 
| 103 | 
            -
                assert( rp = integer_times.parent("PRGT#run") )
         | 
| 104 | 
            -
                assert_in_delta(rp.total, rp.child, 0.01)
         | 
| 105 | 
            -
                assert_equal("1/5", rp.calls)
         | 
| 106 | 
            -
             | 
| 107 | 
            -
                assert_in_delta(4*fp.total, gp.total, 0.05)
         | 
| 108 | 
            -
                assert_in_delta(fp.total + gp.total, rp.total, 0.05)
         | 
| 109 | 
            -
                assert_in_delta(integer_times.metrics.total, rp.total, 0.05)
         | 
| 110 | 
            -
             | 
| 111 | 
            -
                assert( fc = integer_times.child("PRGT#f") )
         | 
| 112 | 
            -
                assert_in_delta(fc.total, fc.child, 0.01)
         | 
| 113 | 
            -
                assert_equal("2/2", fc.calls)
         | 
| 114 | 
            -
             | 
| 115 | 
            -
                assert( gc = integer_times.child("PRGT#g") )
         | 
| 116 | 
            -
                assert_in_delta(gc.total, gc.child, 0.01)
         | 
| 117 | 
            -
                assert_equal("2/2", gc.calls)
         | 
| 118 | 
            -
             | 
| 119 | 
            -
                assert( ks = integer_times.child("Kernel#sleep") )
         | 
| 120 | 
            -
                assert_in_delta(ks.total, ks.self_t, 0.01)
         | 
| 121 | 
            -
                assert_equal("12/12", ks.calls)
         | 
| 122 | 
            -
             | 
| 123 | 
            -
                assert_in_delta(4*fc.total, gc.total, 0.05)
         | 
| 124 | 
            -
                assert_in_delta(fp.total + gc.total, ks.total, 0.05)
         | 
| 125 | 
            -
                assert_in_delta(integer_times.metrics.total, ks.total, 0.05)
         | 
| 126 | 
            -
              end
         | 
| 127 | 
            -
            end
         | 
| 1 | 
            +
            #!/usr/bin/env ruby
         | 
| 2 | 
            +
            # encoding: UTF-8
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            require File.expand_path('../test_helper', __FILE__)
         | 
| 5 | 
            +
            require 'stringio'
         | 
| 6 | 
            +
            require 'fileutils'
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            # --- code to be tested ---
         | 
| 9 | 
            +
            module PRGT
         | 
| 10 | 
            +
              extend self
         | 
| 11 | 
            +
             | 
| 12 | 
            +
              def f(n)
         | 
| 13 | 
            +
                n.times { sleep 0.1 }
         | 
| 14 | 
            +
              end
         | 
| 15 | 
            +
             | 
| 16 | 
            +
              def g(n)
         | 
| 17 | 
            +
                n.times { sleep 0.2 }
         | 
| 18 | 
            +
              end
         | 
| 19 | 
            +
             | 
| 20 | 
            +
              def run
         | 
| 21 | 
            +
                2.times { f(2); g(4) }
         | 
| 22 | 
            +
              end
         | 
| 23 | 
            +
            end
         | 
| 24 | 
            +
             | 
| 25 | 
            +
            # --- expected test output ---
         | 
| 26 | 
            +
            =begin
         | 
| 27 | 
            +
            Measure Mode: wall_time
         | 
| 28 | 
            +
            Thread ID: 1307675084040
         | 
| 29 | 
            +
            Fiber ID: 1307708787440
         | 
| 30 | 
            +
            Total Time: 2.0939999999973224
         | 
| 31 | 
            +
            Sort by:
         | 
| 32 | 
            +
             | 
| 33 | 
            +
              %total   %self      total       self       wait      child            calls     name
         | 
| 34 | 
            +
            --------------------------------------------------------------------------------
         | 
| 35 | 
            +
                                  1.657      0.000      0.000      1.657              2/2     Integer#times
         | 
| 36 | 
            +
              79.13%   0.00%      1.657      0.000      0.000      1.657                2     PRGT#g
         | 
| 37 | 
            +
                                  1.657      0.000      0.000      1.657              2/5     Integer#times
         | 
| 38 | 
            +
            --------------------------------------------------------------------------------
         | 
| 39 | 
            +
                                  2.094      2.094      0.000      0.000            12/12     Integer#times
         | 
| 40 | 
            +
             100.00% 100.00%      2.094      2.094      0.000      0.000               12     Kernel#sleep
         | 
| 41 | 
            +
            --------------------------------------------------------------------------------
         | 
| 42 | 
            +
                                  0.437      0.000      0.000      0.437              2/2     Integer#times
         | 
| 43 | 
            +
              20.87%   0.00%      0.437      0.000      0.000      0.437                2     PRGT#f
         | 
| 44 | 
            +
                                  0.437      0.000      0.000      0.437              2/5     Integer#times
         | 
| 45 | 
            +
            --------------------------------------------------------------------------------
         | 
| 46 | 
            +
                                  0.437      0.000      0.000      0.437              2/5     PRGT#f
         | 
| 47 | 
            +
                                  1.657      0.000      0.000      1.657              2/5     PRGT#g
         | 
| 48 | 
            +
                                  2.094      0.000      0.000      2.094              1/5     PRGT#run
         | 
| 49 | 
            +
             100.00%   0.00%      2.094      0.000      0.000      2.094                5    *Integer#times
         | 
| 50 | 
            +
                                  2.094      2.094      0.000      0.000            12/12     Kernel#sleep
         | 
| 51 | 
            +
                                  1.657      0.000      0.000      1.657              2/2     PRGT#g
         | 
| 52 | 
            +
                                  0.437      0.000      0.000      0.437              2/2     PRGT#f
         | 
| 53 | 
            +
            --------------------------------------------------------------------------------
         | 
| 54 | 
            +
                                  2.094      0.000      0.000      2.094              1/1     PrintingRecursiveGraphTest#setup
         | 
| 55 | 
            +
             100.00%   0.00%      2.094      0.000      0.000      2.094                1     PRGT#run
         | 
| 56 | 
            +
                                  2.094      0.000      0.000      2.094              1/5     Integer#times
         | 
| 57 | 
            +
            --------------------------------------------------------------------------------
         | 
| 58 | 
            +
             100.00%   0.00%      2.094      0.000      0.000      2.094                1     PrintingRecursiveGraphTest#setup
         | 
| 59 | 
            +
                                  2.094      0.000      0.000      2.094              1/1     PRGT#run
         | 
| 60 | 
            +
             | 
| 61 | 
            +
            * indicates recursively called methods
         | 
| 62 | 
            +
            =end
         | 
| 63 | 
            +
             | 
| 64 | 
            +
            class PrintingRecursiveGraphTest < TestCase
         | 
| 65 | 
            +
              def setup
         | 
| 66 | 
            +
                # WALL_TIME so we can use sleep in our test and get same measurements on linux and windows
         | 
| 67 | 
            +
                RubyProf::measure_mode = RubyProf::WALL_TIME
         | 
| 68 | 
            +
                @result = RubyProf.profile do
         | 
| 69 | 
            +
                  PRGT.run
         | 
| 70 | 
            +
                end
         | 
| 71 | 
            +
              end
         | 
| 72 | 
            +
             | 
| 73 | 
            +
              def test_printing_rescursive_graph
         | 
| 74 | 
            +
                printer = RubyProf::GraphPrinter.new(@result)
         | 
| 75 | 
            +
                buffer = ''
         | 
| 76 | 
            +
                printer.print(StringIO.new(buffer))
         | 
| 77 | 
            +
                puts buffer if ENV['SHOW_RUBY_PROF_PRINTER_OUTPUT'] == "1"
         | 
| 78 | 
            +
             | 
| 79 | 
            +
                refute_nil(buffer)
         | 
| 80 | 
            +
              end
         | 
| 81 | 
            +
            end
         | 
    
        data/test/rack_test.rb
    CHANGED
    
    | @@ -1,93 +1,157 @@ | |
| 1 | 
            -
            #!/usr/bin/env ruby
         | 
| 2 | 
            -
            # encoding: UTF-8
         | 
| 3 | 
            -
             | 
| 4 | 
            -
            require File.expand_path('../test_helper', __FILE__)
         | 
| 5 | 
            -
             | 
| 6 | 
            -
            class FakeRackApp
         | 
| 7 | 
            -
              def call(env)
         | 
| 8 | 
            -
              end
         | 
| 9 | 
            -
            end
         | 
| 10 | 
            -
             | 
| 11 | 
            -
            module Rack
         | 
| 12 | 
            -
              class Request
         | 
| 13 | 
            -
                def initialize(env)
         | 
| 14 | 
            -
                  if env == :fake_env
         | 
| 15 | 
            -
                    @env = {}
         | 
| 16 | 
            -
                  else
         | 
| 17 | 
            -
                    @env = env
         | 
| 18 | 
            -
                  end
         | 
| 19 | 
            -
                end
         | 
| 20 | 
            -
             | 
| 21 | 
            -
                def path
         | 
| 22 | 
            -
                  @env[:path] || '/path/to/resource.json'
         | 
| 23 | 
            -
                end
         | 
| 24 | 
            -
              end
         | 
| 25 | 
            -
            end
         | 
| 26 | 
            -
             | 
| 27 | 
            -
             | 
| 28 | 
            -
               | 
| 29 | 
            -
                 | 
| 30 | 
            -
             | 
| 31 | 
            -
             | 
| 32 | 
            -
             | 
| 33 | 
            -
             | 
| 34 | 
            -
             | 
| 35 | 
            -
             | 
| 36 | 
            -
             | 
| 37 | 
            -
             | 
| 38 | 
            -
             | 
| 39 | 
            -
             | 
| 40 | 
            -
                 | 
| 41 | 
            -
             | 
| 42 | 
            -
                 | 
| 43 | 
            -
             | 
| 44 | 
            -
                 | 
| 45 | 
            -
             | 
| 46 | 
            -
             | 
| 47 | 
            -
             | 
| 48 | 
            -
             | 
| 49 | 
            -
             | 
| 50 | 
            -
             | 
| 51 | 
            -
             | 
| 52 | 
            -
             | 
| 53 | 
            -
             | 
| 54 | 
            -
             | 
| 55 | 
            -
             | 
| 56 | 
            -
             | 
| 57 | 
            -
                 | 
| 58 | 
            -
             | 
| 59 | 
            -
             | 
| 60 | 
            -
             | 
| 61 | 
            -
             | 
| 62 | 
            -
             | 
| 63 | 
            -
             | 
| 64 | 
            -
             | 
| 65 | 
            -
             | 
| 66 | 
            -
             | 
| 67 | 
            -
             | 
| 68 | 
            -
             | 
| 69 | 
            -
             | 
| 70 | 
            -
                 | 
| 71 | 
            -
             | 
| 72 | 
            -
             | 
| 73 | 
            -
             | 
| 74 | 
            -
             | 
| 75 | 
            -
             | 
| 76 | 
            -
                 | 
| 77 | 
            -
             | 
| 78 | 
            -
             | 
| 79 | 
            -
             | 
| 80 | 
            -
             | 
| 81 | 
            -
             | 
| 82 | 
            -
             | 
| 83 | 
            -
                 | 
| 84 | 
            -
             | 
| 85 | 
            -
                 | 
| 86 | 
            -
                 | 
| 87 | 
            -
             | 
| 88 | 
            -
             | 
| 89 | 
            -
             | 
| 90 | 
            -
             | 
| 91 | 
            -
             | 
| 92 | 
            -
               | 
| 93 | 
            -
             | 
| 1 | 
            +
            #!/usr/bin/env ruby
         | 
| 2 | 
            +
            # encoding: UTF-8
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            require File.expand_path('../test_helper', __FILE__)
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            class FakeRackApp
         | 
| 7 | 
            +
              def call(env)
         | 
| 8 | 
            +
              end
         | 
| 9 | 
            +
            end
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            module Rack
         | 
| 12 | 
            +
              class Request
         | 
| 13 | 
            +
                def initialize(env)
         | 
| 14 | 
            +
                  if env == :fake_env
         | 
| 15 | 
            +
                    @env = {}
         | 
| 16 | 
            +
                  else
         | 
| 17 | 
            +
                    @env = env
         | 
| 18 | 
            +
                  end
         | 
| 19 | 
            +
                end
         | 
| 20 | 
            +
             | 
| 21 | 
            +
                def path
         | 
| 22 | 
            +
                  @env[:path] || '/path/to/resource.json'
         | 
| 23 | 
            +
                end
         | 
| 24 | 
            +
              end
         | 
| 25 | 
            +
            end
         | 
| 26 | 
            +
             | 
| 27 | 
            +
            module Rack
         | 
| 28 | 
            +
              class RubyProf
         | 
| 29 | 
            +
                attr_reader :_profiler
         | 
| 30 | 
            +
             | 
| 31 | 
            +
                def public_delete_profiler!
         | 
| 32 | 
            +
                  delete_profiler!
         | 
| 33 | 
            +
                end
         | 
| 34 | 
            +
              end
         | 
| 35 | 
            +
            end
         | 
| 36 | 
            +
             | 
| 37 | 
            +
            class RackTest < TestCase
         | 
| 38 | 
            +
              def test_create_print_path
         | 
| 39 | 
            +
                path = Dir.mktmpdir
         | 
| 40 | 
            +
                Dir.delete(path)
         | 
| 41 | 
            +
             | 
| 42 | 
            +
                Rack::RubyProf.new(FakeRackApp.new, :path => path)
         | 
| 43 | 
            +
             | 
| 44 | 
            +
                assert(Dir.exist?(path))
         | 
| 45 | 
            +
              end
         | 
| 46 | 
            +
             | 
| 47 | 
            +
              def test_create_profile_reports
         | 
| 48 | 
            +
                path = Dir.mktmpdir
         | 
| 49 | 
            +
             | 
| 50 | 
            +
                adapter = Rack::RubyProf.new(FakeRackApp.new, :path => path)
         | 
| 51 | 
            +
             | 
| 52 | 
            +
                adapter.call(:fake_env)
         | 
| 53 | 
            +
             | 
| 54 | 
            +
                %w(flat.txt graph.txt graph.html call_stack.html).each do |base_name|
         | 
| 55 | 
            +
                  file_path = ::File.join(path, "path-to-resource.json-#{base_name}")
         | 
| 56 | 
            +
                  assert(File.exist?(file_path))
         | 
| 57 | 
            +
                end
         | 
| 58 | 
            +
              end
         | 
| 59 | 
            +
             | 
| 60 | 
            +
              def test_skip_paths
         | 
| 61 | 
            +
                path = Dir.mktmpdir
         | 
| 62 | 
            +
             | 
| 63 | 
            +
                adapter = Rack::RubyProf.new(FakeRackApp.new, :path => path, :skip_paths => [%r{\.json$}])
         | 
| 64 | 
            +
             | 
| 65 | 
            +
                adapter.call(:fake_env)
         | 
| 66 | 
            +
             | 
| 67 | 
            +
                %w(flat.txt graph.txt graph.html call_stack.html).each do |base_name|
         | 
| 68 | 
            +
                  file_path = ::File.join(path, "path-to-resource.json-#{base_name}")
         | 
| 69 | 
            +
                  assert(!File.exist?(file_path))
         | 
| 70 | 
            +
                end
         | 
| 71 | 
            +
              end
         | 
| 72 | 
            +
             | 
| 73 | 
            +
              def test_only_paths
         | 
| 74 | 
            +
                path = Dir.mktmpdir
         | 
| 75 | 
            +
             | 
| 76 | 
            +
                adapter = Rack::RubyProf.new(FakeRackApp.new, :path => path, :only_paths => [%r{\.json$}])
         | 
| 77 | 
            +
             | 
| 78 | 
            +
                adapter.call({path: '/path/to/resource.json'})
         | 
| 79 | 
            +
             | 
| 80 | 
            +
                %w(flat.txt graph.txt graph.html call_stack.html).each do |base_name|
         | 
| 81 | 
            +
                  file_path = ::File.join(path, "path-to-resource.json-#{base_name}")
         | 
| 82 | 
            +
                  assert(File.exist?(file_path))
         | 
| 83 | 
            +
                end
         | 
| 84 | 
            +
             | 
| 85 | 
            +
                adapter.call({path: '/path/to/resource.html'})
         | 
| 86 | 
            +
                %w(flat.txt graph.txt graph.html call_stack.html).each do |base_name|
         | 
| 87 | 
            +
                  file_path = ::File.join(path, "path-to-resource.html-#{base_name}")
         | 
| 88 | 
            +
                  assert(!File.exist?(file_path))
         | 
| 89 | 
            +
                end
         | 
| 90 | 
            +
              end
         | 
| 91 | 
            +
             | 
| 92 | 
            +
              def test_allows_lazy_filename_setting
         | 
| 93 | 
            +
                path = Dir.mktmpdir
         | 
| 94 | 
            +
             | 
| 95 | 
            +
                printer = {::RubyProf::FlatPrinter => lambda { 'dynamic.txt' }}
         | 
| 96 | 
            +
                adapter = Rack::RubyProf.new(FakeRackApp.new, :path => path, :printers => printer)
         | 
| 97 | 
            +
             | 
| 98 | 
            +
                adapter.call(:fake_env)
         | 
| 99 | 
            +
             | 
| 100 | 
            +
                file_path = ::File.join(path, 'path-to-resource.json-dynamic.txt')
         | 
| 101 | 
            +
                assert(File.exist?(file_path))
         | 
| 102 | 
            +
              end
         | 
| 103 | 
            +
             | 
| 104 | 
            +
              def test_works_for_multiple_requests
         | 
| 105 | 
            +
                path = Dir.mktmpdir
         | 
| 106 | 
            +
             | 
| 107 | 
            +
                adapter = Rack::RubyProf.new(FakeRackApp.new, :path => path, :max_requests => 2)
         | 
| 108 | 
            +
             | 
| 109 | 
            +
                # make a 1st request, and check that this didn't create any files
         | 
| 110 | 
            +
                adapter.call(:fake_env)
         | 
| 111 | 
            +
                assert(Dir["#{path}/*"].empty?)
         | 
| 112 | 
            +
             | 
| 113 | 
            +
                # now a second request should create all the expected files
         | 
| 114 | 
            +
                adapter.call(:fake_env)
         | 
| 115 | 
            +
                %w(flat.txt graph.txt graph.html call_stack.html).each do |base_name|
         | 
| 116 | 
            +
                  file_path = ::File.join(path, "multi-requests-2-#{base_name}")
         | 
| 117 | 
            +
                  assert(File.exist?(file_path))
         | 
| 118 | 
            +
                end
         | 
| 119 | 
            +
             | 
| 120 | 
            +
                # let's clean up
         | 
| 121 | 
            +
                FileUtils.rm_rf(Dir["#{path}/*"])
         | 
| 122 | 
            +
             | 
| 123 | 
            +
                # and do the same again for the next 2 requests
         | 
| 124 | 
            +
                adapter.call(:fake_env)
         | 
| 125 | 
            +
                assert(Dir["#{path}/*"].empty?)
         | 
| 126 | 
            +
             | 
| 127 | 
            +
                adapter.call(:fake_env)
         | 
| 128 | 
            +
                %w(flat.txt graph.txt graph.html call_stack.html).each do |base_name|
         | 
| 129 | 
            +
                  file_path = ::File.join(path, "multi-requests-2-#{base_name}")
         | 
| 130 | 
            +
                  assert(File.exist?(file_path))
         | 
| 131 | 
            +
                end
         | 
| 132 | 
            +
              end
         | 
| 133 | 
            +
             | 
| 134 | 
            +
              def test_tries_to_print_results_if_shut_down_before_max_requests_reached
         | 
| 135 | 
            +
                path = Dir.mktmpdir
         | 
| 136 | 
            +
             | 
| 137 | 
            +
                adapter = Rack::RubyProf.new(FakeRackApp.new, :path => path, :max_requests => 100)
         | 
| 138 | 
            +
             | 
| 139 | 
            +
                # make a 1st request, and check that this didn't create any files
         | 
| 140 | 
            +
                adapter.call(:fake_env)
         | 
| 141 | 
            +
                assert(Dir["#{path}/*"].empty?)
         | 
| 142 | 
            +
             | 
| 143 | 
            +
                adapter.public_delete_profiler!
         | 
| 144 | 
            +
             | 
| 145 | 
            +
                %w(flat.txt graph.txt graph.html call_stack.html).each do |base_name|
         | 
| 146 | 
            +
                  file_path = ::File.join(path, "multi-requests-1-#{base_name}")
         | 
| 147 | 
            +
                  assert(File.exist?(file_path))
         | 
| 148 | 
            +
                end
         | 
| 149 | 
            +
              end
         | 
| 150 | 
            +
             | 
| 151 | 
            +
              def test_it_uses_separate_profilers_if_not_aggregating_multiple_requests
         | 
| 152 | 
            +
                adapter1 = Rack::RubyProf.new(FakeRackApp.new)
         | 
| 153 | 
            +
                adapter2 = Rack::RubyProf.new(FakeRackApp.new)
         | 
| 154 | 
            +
             | 
| 155 | 
            +
                assert(adapter1.object_id != adapter2.object_id)
         | 
| 156 | 
            +
              end
         | 
| 157 | 
            +
            end
         |