2006-07-08 14:14:49 -04:00
|
|
|
require File.dirname(__FILE__) + '/abstract_unit'
|
2005-10-13 15:05:32 -04:00
|
|
|
require 'stringio'
|
|
|
|
|
|
|
|
class CleanLoggerTest < Test::Unit::TestCase
|
|
|
|
def setup
|
|
|
|
@out = StringIO.new
|
|
|
|
@logger = Logger.new(@out)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_format_message
|
|
|
|
@logger.error 'error'
|
|
|
|
assert_equal "error\n", @out.string
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_silence
|
|
|
|
# Without yielding self.
|
|
|
|
@logger.silence do
|
|
|
|
@logger.debug 'debug'
|
|
|
|
@logger.info 'info'
|
|
|
|
@logger.warn 'warn'
|
|
|
|
@logger.error 'error'
|
|
|
|
@logger.fatal 'fatal'
|
|
|
|
end
|
|
|
|
|
|
|
|
# Yielding self.
|
|
|
|
@logger.silence do |logger|
|
|
|
|
logger.debug 'debug'
|
|
|
|
logger.info 'info'
|
|
|
|
logger.warn 'warn'
|
|
|
|
logger.error 'error'
|
|
|
|
logger.fatal 'fatal'
|
|
|
|
end
|
|
|
|
|
2005-10-23 16:00:05 -04:00
|
|
|
# Silencer off.
|
|
|
|
Logger.silencer = false
|
|
|
|
@logger.silence do |logger|
|
|
|
|
logger.warn 'unsilenced'
|
|
|
|
end
|
|
|
|
Logger.silencer = true
|
|
|
|
|
|
|
|
assert_equal "error\nfatal\nerror\nfatal\nunsilenced\n", @out.string
|
2005-10-13 15:05:32 -04:00
|
|
|
end
|
2007-02-24 19:07:54 -05:00
|
|
|
|
|
|
|
def test_datetime_format
|
|
|
|
@logger.formatter = Logger::Formatter.new
|
|
|
|
@logger.datetime_format = "%Y-%m-%d"
|
|
|
|
@logger.debug 'debug'
|
|
|
|
assert_match(/D, \[\d\d\d\d-\d\d-\d\d#\d+\] DEBUG -- : debug/, @out.string)
|
|
|
|
end
|
2005-10-13 15:05:32 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
class CleanLogger_182_to_183_Test < Test::Unit::TestCase
|
|
|
|
def setup
|
2005-11-21 02:29:27 -05:00
|
|
|
silence_warnings do
|
|
|
|
if Logger.method_defined?(:formatter=)
|
|
|
|
Logger.send(:alias_method, :hide_formatter=, :formatter=)
|
|
|
|
Logger.send(:undef_method, :formatter=)
|
|
|
|
else
|
|
|
|
Logger.send(:define_method, :formatter=) { }
|
|
|
|
end
|
|
|
|
load File.dirname(__FILE__) + '/../lib/active_support/clean_logger.rb'
|
2005-10-13 15:05:32 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
@out = StringIO.new
|
|
|
|
@logger = Logger.new(@out)
|
|
|
|
@logger.progname = 'CLEAN LOGGER TEST'
|
|
|
|
end
|
|
|
|
|
|
|
|
def teardown
|
2005-11-21 02:29:27 -05:00
|
|
|
silence_warnings do
|
|
|
|
if Logger.method_defined?(:hide_formatter=)
|
|
|
|
Logger.send(:alias_method, :formatter=, :hide_formatter=)
|
|
|
|
else
|
|
|
|
Logger.send(:undef_method, :formatter=)
|
|
|
|
end
|
|
|
|
load File.dirname(__FILE__) + '/../lib/active_support/clean_logger.rb'
|
2005-10-13 15:05:32 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Since we've fooled Logger into thinking we're on 1.8.2 if we're on 1.8.3
|
|
|
|
# and on 1.8.3 if we're on 1.8.2, it'll define format_message with the
|
|
|
|
# wrong order of arguments and therefore print progname instead of msg.
|
|
|
|
def test_format_message_with_faked_version
|
|
|
|
@logger.error 'error'
|
|
|
|
assert_equal "CLEAN LOGGER TEST\n", @out.string
|
|
|
|
end
|
|
|
|
end
|