1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/activesupport/test/clean_logger_test.rb
Jeremy Kemper d1ac316fa4 r3219@asus: jeremy | 2005-11-20 03:07:19 -0800
silence necessary warnings in logger test.  guard against multiple requires in kernel test.


git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@3131 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
2005-11-21 07:29:27 +00:00

82 lines
2.2 KiB
Ruby

require 'test/unit'
require 'stringio'
require File.dirname(__FILE__) + '/../lib/active_support/clean_logger'
require File.dirname(__FILE__) + '/../lib/active_support/core_ext/kernel.rb' unless defined? silence_warnings
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
# 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
end
end
class CleanLogger_182_to_183_Test < Test::Unit::TestCase
def setup
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'
end
@out = StringIO.new
@logger = Logger.new(@out)
@logger.progname = 'CLEAN LOGGER TEST'
end
def teardown
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'
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