Class: Ocular::Logging::MultiLogger

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

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeMultiLogger

Returns a new instance of MultiLogger.



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

def initialize
    @loggers = []
end

Instance Attribute Details

#loggersObject (readonly)

Returns the value of attribute loggers.



7
8
9
# File 'lib/ocular/logging/multilogger.rb', line 7

def loggers
  @loggers
end

Instance Method Details

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



17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# File 'lib/ocular/logging/multilogger.rb', line 17

def add(severity, message = nil, run_id = nil, &block)

    if message.nil?
        if block_given?
            message = yield
        else
            message = "N/A"
        end
    end

    @loggers.each do |logger|
        logger.add(severity, message, run_id)
    end
    
end

#add_logger(logger) ⇒ Object



13
14
15
# File 'lib/ocular/logging/multilogger.rb', line 13

def add_logger(logger)
    @loggers << logger
end

#log_cause(type, environment, run_id) ⇒ Object



39
40
41
42
43
# File 'lib/ocular/logging/multilogger.rb', line 39

def log_cause(type, environment, run_id)
    @loggers.each do |logger|
        logger.log_cause(type, environment, run_id)
    end
end

#log_event(property, value, run_id) ⇒ Object



33
34
35
36
37
# File 'lib/ocular/logging/multilogger.rb', line 33

def log_event(property, value, run_id)
    @loggers.each do |logger|
        logger.log_event(property, value, run_id)
    end
end

#log_timing(key, value, run_id) ⇒ Object



45
46
47
48
49
# File 'lib/ocular/logging/multilogger.rb', line 45

def log_timing(key, value, run_id)
    @loggers.each do |logger|
        logger.log_timing(key, value, run_id)
    end
end