对 ruby 相当陌生,玩过 Mini Test 和 log4r,尝试编写一个包装类。
收到以下错误:
Run options: --seed 18181
# Running tests:
E
Finished tests in 0.015625s, 63.9996 tests/s, 0.0000 assertions/s.
1) Error:
test_debug_messages(TestLogger):
NameError: uninitialized constant Logger
/home/jamlopez/scripts/Yatra.Next/rpm_framework/lib/rpm/core/logger.rb:7:in `initialize'
logger.rb:6:in `new'
logger.rb:6:in `setup'
1 tests, 0 assertions, 0 failures, 1 errors, 0 skips
这是课程:
require 'log4r'
# RPM Framework Logger
# Based on and utilizing log4r >= 1.1.10
class RPMLogger
def initialize
@log = ::Logger.new 'log'
@log.outputters = Outputter.stdout
@logfile_location = brpm_home
@timenow = eval( Time.now.utc.iso8601 )
end
def debug( msg )
@log.debug ( '[DEBUG] ' + @timenow + " #{msg}" )
end
def info( msg )
@log.info ( '[INFO] ' + @timenow + " #{msg}" )
end
def warn( msg )
@log.warn ( '[WARNING] ' + @timenow + " #{msg}" )
end
def error( msg )
@log.error ( '[ERROR] ' + @timenow + " #{msg}" )
end
def fatal( msg )
@log.fatal ( '[FATAL] ' + @timenow + " #{msg}" )
end
end
这是测试:
require 'minitest/autorun'
require_relative "./../../../lib/rpm/core/logger"
class TestLogger < MiniTest::Unit::TestCase
def setup
@logger = RPMLogger.new
@test_msg = "This is a test log message!"
end
def test_debug_messages
log = @logger.debug( @test_msg )
assert_match "/^[DEBUG] /", log, msg=nil
end
end
我将是第一个承认两个文件中可能存在几个错误的人(因为我仍在学习),但我会尝试一步一步来。
可能有几种方法可以做到这一点,我只是不确定这是否是其中之一。
从表面上看,使用@log = ::Logger.new
似乎是合理的,但也许我应该include log4r
改为扩展模块?(每个Ruby:模块、要求和包含)
我搜索了相关的 SO 文章,并在网上搜索了有关“初始化”的参数。要么他们没有直接关系,要么我误解了他们。任何帮助表示赞赏。