Class: ActiveSupport::LogSubscriber::TestHelper::MockLogger
- Includes:
- ActiveSupport::Logger::Severity
- Defined in:
- lib/active_support/log_subscriber/test_helper.rb
Instance Attribute Summary collapse
-
#flush_count ⇒ Object
readonly
Returns the value of attribute flush_count.
-
#level ⇒ Object
Returns the value of attribute level.
Instance Method Summary collapse
- #flush ⇒ Object
-
#initialize(level = DEBUG) ⇒ MockLogger
constructor
A new instance of MockLogger.
- #logged(level) ⇒ Object
- #method_missing(level, message = nil) ⇒ Object
Constructor Details
#initialize(level = DEBUG) ⇒ MockLogger
Returns a new instance of MockLogger.
58 59 60 61 62 |
# File 'lib/active_support/log_subscriber/test_helper.rb', line 58 def initialize(level = DEBUG) @flush_count = 0 @level = level @logged = Hash.new { |h, k| h[k] = [] } end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(level, message = nil) ⇒ Object
64 65 66 67 68 69 70 |
# File 'lib/active_support/log_subscriber/test_helper.rb', line 64 def method_missing(level, = nil) if block_given? @logged[level] << yield else @logged[level] << end end |
Instance Attribute Details
#flush_count ⇒ Object (readonly)
Returns the value of attribute flush_count.
55 56 57 |
# File 'lib/active_support/log_subscriber/test_helper.rb', line 55 def flush_count @flush_count end |
#level ⇒ Object
Returns the value of attribute level.
56 57 58 |
# File 'lib/active_support/log_subscriber/test_helper.rb', line 56 def level @level end |
Instance Method Details
#flush ⇒ Object
76 77 78 |
# File 'lib/active_support/log_subscriber/test_helper.rb', line 76 def flush @flush_count += 1 end |
#logged(level) ⇒ Object
72 73 74 |
# File 'lib/active_support/log_subscriber/test_helper.rb', line 72 def logged(level) @logged[level].compact.map { |l| l.to_s.strip } end |