# Copyright 2008-2015 Nokia Networks
# Copyright 2016- Robot Framework Foundation
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from . import pyloggingconf
from .debugfile import DebugFile
from .listeners import Listeners, LibraryListeners
from .logger import LOGGER
from .loggerapi import LoggerApi
from .loggerhelper import AbstractLogger
from .xmllogger import XmlLoggerAdapter
[docs]
class Output(AbstractLogger, LoggerApi):
def __init__(self, settings):
AbstractLogger.__init__(self)
self._xml_logger = XmlLoggerAdapter(settings.output, settings.log_level,
settings.rpa,
legacy_output=settings.legacy_output)
self.listeners = Listeners(settings.listeners, settings.log_level)
self.library_listeners = LibraryListeners(settings.log_level)
self._register_loggers(DebugFile(settings.debug_file))
self._settings = settings
@property
def initial_log_level(self):
return self._settings.log_level
def _register_loggers(self, debug_file):
LOGGER.register_xml_logger(self._xml_logger)
LOGGER.register_listeners(self.listeners or None, self.library_listeners)
if debug_file:
LOGGER.register_logger(debug_file)
[docs]
def register_error_listener(self, listener):
LOGGER.register_error_listener(listener)
@property
def delayed_logging(self):
return LOGGER.delayed_logging
[docs]
def close(self, result):
self._xml_logger.logger.visit_statistics(result.statistics)
self._xml_logger.close()
LOGGER.unregister_xml_logger()
LOGGER.output_file(self._settings['Output'])
[docs]
def start_suite(self, data, result):
LOGGER.start_suite(data, result)
[docs]
def end_suite(self, data, result):
LOGGER.end_suite(data, result)
[docs]
def start_test(self, data, result):
LOGGER.start_test(data, result)
[docs]
def end_test(self, data, result):
LOGGER.end_test(data, result)
[docs]
def start_keyword(self, data, result):
LOGGER.start_keyword(data, result)
[docs]
def end_keyword(self, data, result):
LOGGER.end_keyword(data, result)
[docs]
def start_user_keyword(self, data, implementation, result):
LOGGER.start_user_keyword(data, implementation, result)
[docs]
def end_user_keyword(self, data, implementation, result):
LOGGER.end_user_keyword(data, implementation, result)
[docs]
def start_library_keyword(self, data, implementation, result):
LOGGER.start_library_keyword(data, implementation, result)
[docs]
def end_library_keyword(self, data, implementation, result):
LOGGER.end_library_keyword(data, implementation, result)
[docs]
def start_invalid_keyword(self, data, implementation, result):
LOGGER.start_invalid_keyword(data, implementation, result)
[docs]
def end_invalid_keyword(self, data, implementation, result):
LOGGER.end_invalid_keyword(data, implementation, result)
[docs]
def start_for(self, data, result):
LOGGER.start_for(data, result)
[docs]
def end_for(self, data, result):
LOGGER.end_for(data, result)
[docs]
def start_for_iteration(self, data, result):
LOGGER.start_for_iteration(data, result)
[docs]
def end_for_iteration(self, data, result):
LOGGER.end_for_iteration(data, result)
[docs]
def start_while(self, data, result):
LOGGER.start_while(data, result)
[docs]
def end_while(self, data, result):
LOGGER.end_while(data, result)
[docs]
def start_while_iteration(self, data, result):
LOGGER.start_while_iteration(data, result)
[docs]
def end_while_iteration(self, data, result):
LOGGER.end_while_iteration(data, result)
[docs]
def start_if(self, data, result):
LOGGER.start_if(data, result)
[docs]
def end_if(self, data, result):
LOGGER.end_if(data, result)
[docs]
def start_if_branch(self, data, result):
LOGGER.start_if_branch(data, result)
[docs]
def end_if_branch(self, data, result):
LOGGER.end_if_branch(data, result)
[docs]
def start_try(self, data, result):
LOGGER.start_try(data, result)
[docs]
def end_try(self, data, result):
LOGGER.end_try(data, result)
[docs]
def start_try_branch(self, data, result):
LOGGER.start_try_branch(data, result)
[docs]
def end_try_branch(self, data, result):
LOGGER.end_try_branch(data, result)
[docs]
def start_var(self, data, result):
LOGGER.start_var(data, result)
[docs]
def end_var(self, data, result):
LOGGER.end_var(data, result)
[docs]
def start_break(self, data, result):
LOGGER.start_break(data, result)
[docs]
def end_break(self, data, result):
LOGGER.end_break(data, result)
[docs]
def start_continue(self, data, result):
LOGGER.start_continue(data, result)
[docs]
def end_continue(self, data, result):
LOGGER.end_continue(data, result)
[docs]
def start_return(self, data, result):
LOGGER.start_return(data, result)
[docs]
def end_return(self, data, result):
LOGGER.end_return(data, result)
[docs]
def start_error(self, data, result):
LOGGER.start_error(data, result)
[docs]
def end_error(self, data, result):
LOGGER.end_error(data, result)
[docs]
def message(self, msg):
LOGGER.log_message(msg)
[docs]
def trace(self, msg, write_if_flat=True):
if write_if_flat or not self._xml_logger.flatten_level:
self.write(msg, 'TRACE')
[docs]
def set_log_level(self, level):
pyloggingconf.set_level(level)
self.listeners.set_log_level(level)
self.library_listeners.set_log_level(level)
return self._xml_logger.set_log_level(level)