質問

Railsのガイドは、デバッグにをより

、私は私のログファイルへの出力をカスタマイズすることができますことを発見しましたこの単純な方法を使用します:

logger.debug "Person attributes hash: #{@person.attributes.inspect}"

私はどのように変数の変更を追跡するために、この使用を決定し、フロー制御を通過します。

私はlogger#debugメソッドが呼ばれた私のコードの行数を確認できるようにしたいと思います。このような何かます:

logger.debug "Person attributes hash: #{@person.attributes.inspect} from line #{LINE_NUMBER_VAR}"
役に立ちましたか?

解決

logger.debug "Person attributes hash: #{@person.attributes.inspect} from line #{__LINE__}"

他のヒント

Loggerのデコレータを使用します:

class LoggerDecorator
  def initialize(logger)
    @logger = logger
  end

  %w{debug info warn error fatal}.each do |method|
    eval(<<-eomethod)
      def #{method}(msg)
        @logger.#{method}(position) {msg}
      end
    eomethod
  end

  private
  def position
    caller.at(1).sub(%r{.*/},'').sub(%r{:in\s.*},'')
  end
end
レール5のように、これは今を介して焼成する

ActiveRecord::Base.verbose_query_logs = true

より多くのドキュメントのnoreferrer">

scroll top