Robot Framework
statusreporter.py
Go to the documentation of this file.
1 # Copyright 2008-2015 Nokia Networks
2 # Copyright 2016- Robot Framework Foundation
3 #
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain a copy of the License at
7 #
8 # http://www.apache.org/licenses/LICENSE-2.0
9 #
10 # Unless required by applicable law or agreed to in writing, software
11 # distributed under the License is distributed on an "AS IS" BASIS,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
15 
16 from robot.errors import (ExecutionFailed, ExecutionStatus, DataError,
17  HandlerExecutionFailed, KeywordError, VariableError)
18 from robot.utils import ErrorDetails, get_timestamp
19 
20 from .modelcombiner import ModelCombiner
21 
22 
24 
25  def __init__(self, data, result, context, run=True, suppress=False):
26  self.datadata = data
27  self.resultresult = result
28  self.contextcontext = context
29  if run:
30  self.pass_statuspass_status = result.PASS
31  result.status = result.NOT_SET
32  else:
33  self.pass_statuspass_status = result.status = result.NOT_RUN
34  self.suppresssuppress = suppress
35  self.initial_test_statusinitial_test_status = None
36 
37  def __enter__(self):
38  context = self.contextcontext
39  result = self.resultresult
40  self.initial_test_statusinitial_test_status = context.test.status if context.test else None
41  result.starttime = get_timestamp()
42  context.start_keyword(ModelCombiner(self.datadata, result))
43  self._warn_if_deprecated_warn_if_deprecated(result.doc, result.name)
44  return self
45 
46  def _warn_if_deprecated(self, doc, name):
47  if doc.startswith('*DEPRECATED') and '*' in doc[1:]:
48  message = ' ' + doc.split('*', 2)[-1].strip()
49  self.contextcontext.warn("Keyword '%s' is deprecated.%s" % (name, message))
50 
51  def __exit__(self, exc_type, exc_val, exc_tb):
52  context = self.contextcontext
53  result = self.resultresult
54  failure = self._get_failure_get_failure(exc_type, exc_val, exc_tb, context)
55  if failure is None:
56  result.status = self.pass_statuspass_status
57  else:
58  result.status = failure.status
59  if result.type == result.TEARDOWN:
60  result.message = failure.message
61  if self.initial_test_statusinitial_test_status == 'PASS':
62  context.test.status = result.status
63  result.endtime = get_timestamp()
64  context.end_keyword(ModelCombiner(self.datadata, result))
65  if failure is not exc_val and not self.suppresssuppress:
66  raise failure
67  return self.suppresssuppress
68 
69  def _get_failure(self, exc_type, exc_value, exc_tb, context):
70  if exc_value is None:
71  return None
72  if isinstance(exc_value, ExecutionStatus):
73  return exc_value
74  if isinstance(exc_value, DataError):
75  msg = exc_value.message
76  context.fail(msg)
77  return ExecutionFailed(msg, syntax=exc_value.syntax)
78  error = ErrorDetails(exc_value)
79  failure = HandlerExecutionFailed(error)
80  if failure.timeout:
81  context.timeout_occurred = True
82  if failure.skip:
83  context.skip(error.message)
84  else:
85  context.fail(error.message)
86  if error.traceback:
87  context.debug(error.traceback)
88  return failure
Used for communicating failures in test execution.
Definition: errors.py:178
def __exit__(self, exc_type, exc_val, exc_tb)
def _get_failure(self, exc_type, exc_value, exc_tb, context)
def __init__(self, data, result, context, run=True, suppress=False)
def warn(msg, html=False)
Writes the message to the log file using the WARN level.
Definition: logger.py:120
def get_timestamp(daysep='', daytimesep=' ', timesep=':', millissep='.')
Definition: robottime.py:335