详解Appium+Python之生成html测试报告
思考:测试用例执行后,如何生成一个直观漂亮的测试报告呢?
分析:
1.unittest单元测试框架本身带有一个texttestrunner类,可以生成txt文本格式的测试报告,但是页面不够直观
2.我们可以导入第三方库,比如常用的htmltestrunner类,可以生成html格式测试报告
3.首先去下载htmltestrunner_py3.py脚本(我这里采用python3.7),然后放置在python3.7路径下的lib目录下,使用时需要导入(即import htmltestrunner_py3)
代码示例如下:
if __name__ == "__main__": #实例化测试套件 suite = unittest.testsuite() #加载测试用例 suite.addtest(testcase("test_login")) #生成测试报告 # 选择指定时间格式 timestr = time.strftime('%y-%m-%d%h%m%s', time.localtime(time.time())) # 定义测试报告存放路径和报告名称 report = os.path.join( path('e://testing_code/code/smartsitetestscript/report/test_report_') + timestr + '.html') with open(report, 'wb') as f: runner = htmltestrunner_py3.htmltestrunner(stream=f, verbosity=2, title='xxxx自动化测试报告', description='执行人:丹姐') runner.run(suite) # 关闭测试报告 f.close()
解析:
1.在测试报告名中显示时间:(引入time包) timestr=time.strftime("%y-%m-%d-%h_%m_%s",time.localtime(time.time()))
time.time():获取当前时间戳
time.ctime():获取当前时间的字符串
time.localtime():当前时间的struct_time形式
time.strftime("%y-%m-%d-%h_%m_%s",time.localtime()):获取特定格式的时间,通常用这个
2.testsuite是个容器,往里面用addtest()添加测试用例
3.report定义报告保存的路径以及文件名
open() 函数用于打开一个文件,创建一个file对象,相关的方法才可以调用它进行读写
语法:open(name[, mode[, buffering]])
- name : 一个包含了你要访问的文件名称的字符串值
- mode : mode 决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)
- buffering : 如果 buffering 的值被设为 0,就不会有寄存。如果 buffering 的值取 1,访问文件时会寄存行。如果将 buffering 的值设为大于 1 的整数,表明了这就是的寄存区的缓冲大小。如果取负值,寄存区的缓冲大小则为系统默认
这里常用的为 open(report,'wb'):以二进制形式打开文件report
4.runner定义测试报告格式,stream定义报告写入的二进制文件,title为报告的标题,description为报告的说明,runner.run()用来运行测试case,注意最后用f.close()将文件关闭!
verbosity表示测试结果的信息复杂度,有三个值
- 0 (静默模式): 你只能获得总的测试用例数和总的结果 比如 总共100个 失败20 成功80
- 1 (默认模式): 非常类似静默模式 只是在每个成功的用例前面有个“.” 每个失败的用例前面有个 “f”
- 2 (详细模式):测试结果会显示每个测试用例的所有相关的信息
测试报告效果图如下所示: