zoukankan      html  css  js  c++  java
  • Appium+Python之生成html测试报告

    思考:测试用例执行后,如何生成一个直观漂亮的测试报告呢?

    分析1.unittest单元测试框架本身带有一个textTestRunner类,可以生成txt文本格式的测试报告,但是页面不够直观

               2.我们可以导入第三方库,比如常用的HTMLTestRunner类,可以生成html格式测试报告

       3.首先去下载HTMLTestRunner_PY3.py脚本(我这里采用Python3.7),然后放置在Python3.7路径下的Lib目录下,使用时需要导入(即import  HTMLTestRunner_PY3)

    HTMLRunner_PY3脚本下载见本人另一篇博文:https://www.cnblogs.com/ZoeLiang/p/10230495.html

    代码示例如下:

    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 (详细模式):测试结果会显示每个测试用例的所有相关的信息

    测试报告效果图如下所示:

    
    
  • 相关阅读:
    HttpRunner接口自动化测试框架
    使用Appium 测试微信小程序和微信公众号方法
    WiFi无线连接真机进行Appium自动化测试方法
    idea tomcat 乱码问题的解决及相关设置
    解决idea导入maven项目缺少jar包的问题
    Docker php安装扩展步骤详解
    Python之No module named setuptools 安装pip
    MySQL中group_concat函数 --- 很有用的一个用来查询出所有group by 分组后所有 同组内的 内容
    Nginx如何来配置隐藏入口文件index.php(代码)
    vueThink框架搭建与填坑(new)
  • 原文地址:https://www.cnblogs.com/ZoeLiang/p/10217601.html
Copyright © 2011-2022 走看看