Class: Ocular::Logging::ConsoleLogger

Inherits:
Object
  • Object
show all
Defined in:
lib/ocular/logging/console_logger.rb

Overview

Most of the Logger class is copied from the Ruby Logger class source code.

Defined Under Namespace

Classes: Formatter

Instance Method Summary collapse

Constructor Details

#initialize(settings = nil) ⇒ ConsoleLogger

Returns a new instance of ConsoleLogger.



8
9
10
11
# File 'lib/ocular/logging/console_logger.rb', line 8

def initialize(settings=nil)
    @level = Severity::INFO
    @formatter = Formatter.new
end

Instance Method Details

#add(severity, message = nil, run_id = nil, &block) ⇒ Object



13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
# File 'lib/ocular/logging/console_logger.rb', line 13

def add(severity, message = nil, run_id = nil, &block)
    severity ||= Severity::UNKNOWN
    if severity < @level
        return true
    end

    if message.nil?
        if block_given?
            message = yield
        else
            message = progname
        end
    end
    
    puts @formatter.format_message(severity, Time.now, message)
    true
end

#log_cause(type, environment, run_id = nil) ⇒ Object



36
37
38
39
40
41
# File 'lib/ocular/logging/console_logger.rb', line 36

def log_cause(type, environment, run_id = nil)
    if @level == Severity::DEBUG
        puts @formatter.format_cause(type, environment, Time.now)
    end
    true
end

#log_event(property, value, run_id = nil) ⇒ Object



31
32
33
34
# File 'lib/ocular/logging/console_logger.rb', line 31

def log_event(property, value, run_id = nil)
    puts @formatter.format_event(property, value, Time.now)
    true
end

#log_timing(key, value, run_id = nil) ⇒ Object



43
44
45
46
# File 'lib/ocular/logging/console_logger.rb', line 43

def log_timing(key, value, run_id = nil)
    puts @formatter.format_timing(key, value, Time.now)
    true
end