最近在做个邮件通知,邮件正文中需要总结一下RF的结果,本来想直接把rebot命令生成的html页面复制上去,后来发现它是基于js生成的。
1. Parse output.xml
rebot命令生成报告是基于RF生成的output.xml, 我们也需要从这里下手。
robot.api提供了解析xml的API
从链接中的例子可以看到主要用到了ExecutionResult和ResultVisitor
ExecutionResult负责解析xml,然后通过ResultVisitor来对结果做一些自定义的修改。
2. ExecutionResult API
我们只是要得到statistics的结果,所以只需用ExecutionResult的返回值Result即可。
Result.statistics主要有以下几个elements:
total:
Instance of TotalStatistics.suite:
Instance of SuiteStatistics.tags:
Instance of TagStatistics.
我们需要逐一的去看看对应instance以及其父类的成员变量,比如我们看文档可以知道TotalStatistics.message可以得到如下结果:
我们就可以通过ExecutionResult(xml_path).statistics.total.message来获取它的值。
关于suite和tags,它们最后是base robot.model.stats.Stat, 其中提供了test case的name,total,passed,elapsed等信息。
3. Handle result code snippet
from pprint import pprint
from robot.api import ExecutionResult
def handle_robot_results(xml_path):
print '='×80
print 'RF Total Result:'
test_stats = ExecutionResult(xml_path).statistics
pprint(test_stats.total.message)
print '='×80
for stats_by_suite in test_stats.suite:
print('{:70} {:^5} {:^5}'.format(stats_by_suite.name,stats_by_suite.total,stats_by_suite.passed))
print '='×80
for stats_by_tag in test_stats.tags:
print('{:50} {:^5} {:^5}'.format(stats_by_tag.name,stats_by_tag.total,stats_by_tag.passed))
print '='×80