Source code for robot.output.output

#  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 LibraryListeners, Listeners
from .logger import LOGGER, LoggerProxy
from .loggerhelper import AbstractLogger
from .xmllogger import XmlLogger, FlatXmlLogger


[docs]class Output(AbstractLogger): def __init__(self, settings): AbstractLogger.__init__(self) self._xmllogger = XmlLogger(settings.output, settings.log_level, settings.rpa) self._flat_xml_logger = None 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 self._flatten_level = 0 @property def flat_xml_logger(self): if self._flat_xml_logger is None: self._flat_xml_logger = FlatXmlLogger(self._xmllogger) return self._flat_xml_logger def _register_loggers(self, debug_file): LOGGER.register_xml_logger(self._xmllogger) 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)
[docs] def close(self, result): self._xmllogger.visit_statistics(result.statistics) self._xmllogger.close() LOGGER.unregister_xml_logger() LOGGER.output_file('Output', self._settings['Output'])
[docs] def start_suite(self, suite): LOGGER.start_suite(suite)
[docs] def end_suite(self, suite): LOGGER.end_suite(suite)
[docs] def start_test(self, test): LOGGER.start_test(test)
[docs] def end_test(self, test): LOGGER.end_test(test)
[docs] def start_keyword(self, kw): LOGGER.start_keyword(kw) if kw.tags.robot('flatten'): self._flatten_level += 1 if self._flatten_level == 1: LOGGER._xml_logger = LoggerProxy(self.flat_xml_logger)
[docs] def end_keyword(self, kw): if kw.tags.robot('flatten'): self._flatten_level -= 1 if not self._flatten_level: LOGGER._xml_logger = LoggerProxy(self._xmllogger) LOGGER.end_keyword(kw)
[docs] def message(self, msg): LOGGER.log_message(msg)
[docs] def trace(self, msg, write_if_flat=True): if write_if_flat or self._flatten_level == 0: 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._xmllogger.set_log_level(level)