aboutsummaryrefslogblamecommitdiffstats
path: root/actionpack/lib/action_view/helpers/benchmark_helper.rb
blob: d43b1653eefa36ae8889168bd0b47d5131ff386b (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11
12
13












                                                                                                        

                              



                                 
                                                               



         
require 'benchmark'

module ActionView
  module Helpers
    module BenchmarkHelper
      # Measures the execution time of a block in a template and reports the result to the log. Example:
      #
      #  <% benchmark "Notes section" do %>
      #    <%= expensive_notes_operation %>
      #  <% end %>
      #
      # Will add something like "Notes section (0.345234)" to the log.
      def benchmark(message = "Benchmarking", &block)
        return if @logger.nil?

        bm = Benchmark.measure do
          block.call
        end
        
        @logger.info("#{message} (#{sprintf("%.5f", bm.real})")
      end
    end
  end
end