用RobotFrameWork做UI自动化时,一般初学者都会选择第三方扩展库SeleniumLibrary进行UI自动化测试,随然已经封装许多浏览器操作方法,但在实际应用,某些方法还是不能满足我们的需求,于是乎,我们就舍弃SeleniumLibrary库,进行自定义库开发,封装selenium的原生方法,结合python+robotframework+selenium进行框架设计。
在封装过程中,碰到一些问题
1在用SeleniumLibrary库的关键字进行UI操作时,碰到错误,会自动调用Capture Page Screenshot 关键字进行截屏,并在日志中显示。当我们进行自定义库,不使用SeleniumLibrary库的关键字时,封装自己截图方法,用pybot运行脚本时,测试报告中截图没有显示,经过一番研究,暴力的方法,直接在日志中插入如下代码:
logger.info('</td></tr><tr><td colspan="3"><a href="{src}"><img src="{src}" width="800px"></a>'.format(src=get_link_path(filePathName,get_project_path())),html=True)