python+selenium生成测试报告的方法(汉化+错误截图+饼图)

在原有HTMLTestRunner.py的基础上优化,添加汉化,截图,饼图,用例失败重试等功能
直接上下载链接:https://github.com/13521269692/HTMLTestRunner_test.git

将下载的HTMLTestRunner放到入…\python\Lib目录下,就可以引用

报告汉化,错误日志

在这里插入图片描述

selenium/appium 截图

截图功能根据测试结果,当结果为fail或error时自动截图

因为要提取用例中的driver变量获取webdriver对象,所以要实现截图功能必须定义在用例中定义webdriver 为driver

@classmethod
    def setUpClass(cls):
        cls.driver = webdriver.Chrome()

或者

def setUp(self):
       
        self.imgs = []    # (可选)初始化截图列表
        self.driver = webdriver.Chrome()

用例失败重试

在实例化HTMLTestRunner 对象时追加参数,retry,指定重试次数,如果save_last_try 为True ,一个用例仅显示最后一次测试的结果。

 runer = HTMLTestRunner(title="带截图的HTML测试报告", description="测试详情", stream=open("sample_test_report.html", "wb"), verbosity=2, retry=2, save_last_try=True)

定义HTML文件名和路径

 #获取当前时间,这样便于下面的使用。
     now = time.strftime("%Y-%m-%d-%H_%M_%S",time.localtime(time.time())) 
     #打开一个文件,将result写入此file中
     filename = r"D:\aa\{0}result.html".format(now)   #根据需要改HTML文件名和路径
     print(filename)
     
     fp = file(filename, 'wb')
   
     runner=HTMLTestRunner.HTMLTestRunner(stream=fp,title = u'流程测试报告', description = u'测试执行情况', save_last_try=True)

注意:
在python3 中因为unittest运行机制变动,在使用setUp/tearDown中初始化/退出driver时,会出现用例执行失败没有截图的问题,所以推荐使用样例中setUpClass/tearDownClass的用法

猜你喜欢

转载自blog.csdn.net/weixin_46055113/article/details/108121679