Sha256: 7f75e9172ffe78ca4b0a16cc800ec0c03a829d5752afb4b8d292974b34964460

Contents?: true

Size: 1.27 KB

Versions: 8

Compression:

Stored size: 1.27 KB

Contents

require 'benchmark'

module Ramaze
  module Helper

    # Little helper to give you a hand when benching parts of actions

    module Bench

      # Will first run an empty loop to determine the overhead it imposes, then
      # goes on to yield your block +iterations+ times.
      #
      # The last yielded return value will be returned upon completion of the
      # benchmark and the result of the benchmark itself will be sent to
      # Log.info
      #
      # Example:
      #
      #   class MainController < Ramaze::Controller
      #     def index
      #       @users = bench{ User.all }
      #       @tags = bench{ Article.tags }
      #     end
      #   end
      #
      # This will show something like following in your log:
      # [..] INFO   Bench ./start.rb:3:in `index': 0.121163845062256
      # [..] INFO   Bench ./start.rb:4:in `index': 2.234987235098341
      #
      # So now we know that the Article.tags call takes the most time and
      # should be improved.

      def bench(iterations = 1)
        result = nil
        from = caller[0]
        delta = Benchmark.realtime{ iterations.times{ nil }}
        taken = Benchmark.realtime{ iterations.times{ result = yield }}
        Log.info "Bench #{from}: #{taken - delta}"
        return result
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 4 rubygems

Version Path
Pistos-ramaze-2009.01 lib/ramaze/helper/bench.rb
Pistos-ramaze-2009.02 lib/ramaze/helper/bench.rb
manveru-ramaze-2009.01 lib/ramaze/helper/bench.rb
ptomato-ramaze-2009.02.1 lib/ramaze/helper/bench.rb
ptomato-ramaze-2009.02 lib/ramaze/helper/bench.rb
ramaze-2009.01 lib/ramaze/helper/bench.rb
ramaze-2009.03 lib/ramaze/helper/bench.rb
ramaze-2009.02 lib/ramaze/helper/bench.rb