Robot Framework Integrated Development Environment (RIDE)
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 robotide.lib.robot.errors import (ExecutionFailed, ExecutionStatus, DataError,
17  HandlerExecutionFailed, KeywordError, VariableError)
18 from robotide.lib.robot.utils import ErrorDetails, get_timestamp
19 
20 
22 
23  def __init__(self, context, result, dry_run_lib_kw=False):
24  self._context_context = context
25  self._result_result = result
26  self._pass_status_pass_status = 'PASS' if not dry_run_lib_kw else 'NOT_RUN'
27  self._test_passed_test_passed = None
28 
29  def __enter__(self):
30  if self._context_context.test:
31  self._test_passed_test_passed = self._context_context.test.passed
32  self._result_result.starttime = get_timestamp()
33  self._context_context.start_keyword(self._result_result)
34  self._warn_if_deprecated_warn_if_deprecated(self._result_result.doc, self._result_result.name)
35 
36  def _warn_if_deprecated(self, doc, name):
37  if doc.startswith('*DEPRECATED') and '*' in doc[1:]:
38  message = ' ' + doc.split('*', 2)[-1].strip()
39  self._context_context.warn("Keyword '%s' is deprecated.%s" % (name, message))
40 
41  def __exit__(self, exc_type, exc_val, exc_tb):
42  context = self._context_context
43  result = self._result_result
44  failure = self._get_failure_get_failure(exc_type, exc_val, exc_tb, context)
45  if failure is None:
46  result.status = self._pass_status_pass_status
47  else:
48  result.status = failure.status
49  if result.type == result.TEARDOWN_TYPE:
50  result.message = failure.message
51  if context.test:
52  context.test.passed = self._test_passed_test_passed and result.passed
53  result.endtime = get_timestamp()
54  context.end_keyword(result)
55  if failure is not exc_val:
56  raise failure
57 
58  def _get_failure(self, exc_type, exc_value, exc_tb, context):
59  if exc_value is None:
60  return None
61  if isinstance(exc_value, ExecutionStatus):
62  return exc_value
63  if isinstance(exc_value, DataError):
64  msg = exc_value.message
65  context.fail(msg)
66  syntax = not isinstance(exc_value, (KeywordError, VariableError))
67  return ExecutionFailed(msg, syntax=syntax)
68  exc_info = (exc_type, exc_value, exc_tb)
69  failure = HandlerExecutionFailed(ErrorDetails(exc_info))
70  if failure.timeout:
71  context.timeout_occurred = True
72  context.fail(failure.full_message)
73  if failure.traceback:
74  context.debug(failure.traceback)
75  return failure
Used for communicating failures in test execution.
Definition: errors.py:177
def __init__(self, context, result, dry_run_lib_kw=False)
def _get_failure(self, exc_type, exc_value, exc_tb, context)
def __exit__(self, exc_type, exc_val, exc_tb)
def warn(msg, html=False)
Writes the message to the log file using the WARN level.
Definition: logger.py:122
def ErrorDetails(exc_info=None, exclude_robot_traces=EXCLUDE_ROBOT_TRACES)
This factory returns an object that wraps the last occurred exception.
Definition: error.py:57
def get_timestamp(daysep='', daytimesep=' ', timesep=':', millissep='.')
Definition: robottime.py:296