Robotframework Listener抛出"无法访问执行上下文"错误

时间:2016-12-21 15:48:33

标签: robotframework

为了支持替代日志记录格式,我开始开发custom Robotframework Listener。使用指南中的示例,我已经能够复制简单的PythonListner example。可以使用以下命令成功运行此示例:

python.exe -m robot.run --listener C:\temp\tiny.py -s Test02.Test C:\temp\Test02

由侦听器类生成的文件包含已发生的不同事件,并且功能正常运行。

将以下行添加到类的__init__方法时:

BuiltIn().get_variable_value('${SUITE SOURCE}')

收到以下回复:

 failed: Creating instance failed: RobotNotRunningError: Cannot access execution context
Traceback (most recent call last):
  File "C:\temp\tiny.py", line 9, in __init__
    print  repr(BuiltIn().get_variables())
  File "C:\Python27\lib\site-packages\robot\libraries\BuiltIn.py", line 940, in get_variables
    return utils.NormalizedDict(self._variables.current, ignore='_')
  File "C:\Python27\lib\site-packages\robot\libraries\BuiltIn.py", line 2669, in _variables
    return self._namespace.variables
  File "C:\Python27\lib\site-packages\robot\libraries\BuiltIn.py", line 2661, in _namespace
    return self._context.namespace
  File "C:\Python27\lib\site-packages\robot\libraries\BuiltIn.py", line 2656, in _context
    raise RobotNotRunningError('Cannot access execution context')
==============================================================================
Test02
==============================================================================
Test02.Test
==============================================================================
Process Data File                                                     | PASS |
------------------------------------------------------------------------------
Test02.Test                                                           | PASS |
1 critical test, 1 passed, 0 failed
1 test total, 1 passed, 0 failed
==============================================================================
Test02                                                                | PASS |
1 critical test, 1 passed, 0 failed
1 test total, 1 passed, 0 failed
==============================================================================
Output:  C:\temp\output.xml
Log:     C:\temp\log.html
Report:  C:\temp\report.html

测试通过,但未生成文件。此结果已在Python 2.7和Robotframework 3.0和2.8.5上复制。这很奇怪,我需要一些帮助来进一步分析或(理想情况下)解决这个问题。

由于Robotframework调用了Python类,我不确定如何继续调试它,所以也可以随意提出建议。在任何情况下,我都会陷入困境,可以使用你的帮助。

1 个答案:

答案 0 :(得分:3)

您正在尝试在测试开始前引用BuiltIn()。这就是错误Cannot access execution context的含义:测试尚未开始,因此没有执行上下文。简而言之,在测试运行之前,您无法访问BuiltIn库的方法。

在测试开始运行之前,您必须等待调用该语句。

例如:

class listener:
    ROBOT_LISTENER_API_VERSION = 2

    def start_suite(self, name, attrs):
        self.suite_source = BuiltIn().get_variable_value('${SUITE SOURCE}')

但是,如果您只需要当前套件的源代码,那么该信息在侦听器方法start_suite中可用。

例如:

class MyListener:
    ROBOT_LISTENER_API_VERSION = 2

    def start_suite(self, name, attrs):
        self.suite_source = attrs["source"]