Source code for robot.output.listenerarguments

#  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
#  Unless required by applicable law or agreed to in writing, software
#  distributed under the License is distributed on an "AS IS" BASIS,
#  See the License for the specific language governing permissions and
#  limitations under the License.

from robot.utils import is_list_like, is_dict_like, is_string, safe_str

[docs]class ListenerArguments: def __init__(self, arguments): self._arguments = arguments self._version2 = None self._version3 = None
[docs] def get_arguments(self, version): if version == 2: if self._version2 is None: self._version2 = self._get_version2_arguments(*self._arguments) return self._version2 else: if self._version3 is None: self._version3 = self._get_version3_arguments(*self._arguments) return self._version3
def _get_version2_arguments(self, *arguments): return arguments def _get_version3_arguments(self, *arguments): return arguments
[docs] @classmethod def by_method_name(cls, name, arguments): Arguments = {'start_suite': StartSuiteArguments, 'end_suite': EndSuiteArguments, 'start_test': StartTestArguments, 'end_test': EndTestArguments, 'start_keyword': StartKeywordArguments, 'end_keyword': EndKeywordArguments, 'log_message': MessageArguments, 'message': MessageArguments}.get(name, ListenerArguments) return Arguments(arguments)
[docs]class MessageArguments(ListenerArguments): def _get_version2_arguments(self, msg): attributes = {'timestamp': msg.timestamp, 'message': msg.message, 'level': msg.level, 'html': 'yes' if msg.html else 'no'} return attributes, def _get_version3_arguments(self, msg): return msg,
class _ListenerArgumentsFromItem(ListenerArguments): _attribute_names = None def _get_version2_arguments(self, item): attributes = dict((name, self._get_attribute_value(item, name)) for name in self._attribute_names) attributes.update(self._get_extra_attributes(item)) return or '', attributes def _get_attribute_value(self, item, name): value = getattr(item, name) return self._take_copy_of_mutable_value(value) def _take_copy_of_mutable_value(self, value): if is_dict_like(value): return dict(value) if is_list_like(value): return list(value) return value def _get_extra_attributes(self, item): return {} def _get_version3_arguments(self, item): return, item.result
[docs]class StartSuiteArguments(_ListenerArgumentsFromItem): _attribute_names = ('id', 'longname', 'doc', 'metadata', 'starttime') def _get_extra_attributes(self, suite): return {'tests': [ for t in suite.tests], 'suites': [ for s in suite.suites], 'totaltests': suite.test_count, 'source': suite.source or ''}
[docs]class EndSuiteArguments(StartSuiteArguments): _attribute_names = ('id', 'longname', 'doc', 'metadata', 'starttime', 'endtime', 'elapsedtime', 'status', 'message') def _get_extra_attributes(self, suite): attrs = StartSuiteArguments._get_extra_attributes(self, suite) attrs['statistics'] = suite.stat_message return attrs
[docs]class StartTestArguments(_ListenerArgumentsFromItem): _attribute_names = ('id', 'longname', 'doc', 'tags', 'lineno', 'source', 'starttime') def _get_extra_attributes(self, test): return {'template': test.template or '', 'originalname':}
[docs]class EndTestArguments(StartTestArguments): _attribute_names = ('id', 'longname', 'doc', 'tags', 'lineno', 'source', 'starttime', 'endtime', 'elapsedtime', 'status', 'message')
[docs]class StartKeywordArguments(_ListenerArgumentsFromItem): _attribute_names = ('doc', 'assign', 'tags', 'lineno', 'source', 'type', 'status', 'starttime') def _get_extra_attributes(self, kw): args = [a if is_string(a) else safe_str(a) for a in kw.args] return {'kwname': kw.kwname or '', 'libname': kw.libname or '', 'args': args}
[docs]class EndKeywordArguments(StartKeywordArguments): _attribute_names = ('doc', 'assign', 'tags', 'lineno', 'source', 'type', 'status', 'starttime', 'endtime', 'elapsedtime')