Railsのログファイルに出力回線番号
-
20-09-2019 - |
質問
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">
所属していません StackOverflow