開発中のコードをテストするための小さなベンチマーク クラスを作成しました。現時点では、すべてのメソッドの最初と最後にクラスを追加する必要があります。コードを乱雑にする必要がないように、その場で先頭に追加したり、追加したりすることは可能ですか?
class ApplicationController    
    before_filter :init_perf
    after_filter :write_perf_results_to_log!
    def init_perf
      @perf ||= Perf.new
    end
    def write_perf_results_to_log!
      @perf.results
    end
end
class Products < ApplicationsController    
    def foo      
      @perf.log(__methond__.to_s)
      caculation = 5 *4
      @perf.write! 
    end
    def bar      
      @perf.log(__methond__.to_s)
      caculation = 1 / 5
      @perf.write! 
    end
end
これがPerfクラスです。サービスフォルダにあります。
class Perf
  def initialize
    @results = []
  end
  def log(note)
    @start = Time.now
    @note = note
  end
  def write!
    if @results.find {|h| h[:note] == @note } # Update :sec method exists in results 
      @results.select { |h| h["note"] == @note; h[":sec"] = (Time.now - @start).round(3) }
    else # Add new Hash to results
      @results << { :note => @note, :sec => (Time.now - @start).round(3) }
    end
  end
  def results
    content = "
    PERFORMANCE STATISTICS!
    "
    @results.each do |r|
      content += r[:note] + "   " + r[:sec].to_s + "
      "
    end
    content += "
    "
    Rails.logger.info content
  end
end