前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[接口测试_B] 07 Pytest的测试报告

[接口测试_B] 07 Pytest的测试报告

作者头像
苦叶子
发布2018-04-17 15:27:45
1.3K0
发布2018-04-17 15:27:45
举报
文章被收录于专栏:开源优测开源优测

pytest命令行运行时,可以直接在控制台中查看到输出的结果,但这样的结果并不直观,也不易于保存用于后续分析和分享。如pytest -s -q test_xx.py的输出结果。

Pytest的报告输出方式

  • JunitXml格式的报告文件:pytest --junitxml=path
  • resultlog文本格式的报告文件:pytest --resultlog=path(不常用,预计在4.0移除)
  • url格式的报告文件,为每个用例或指定用例生成一个url:pytest --pastebin=all,只输出失败的,可以将all换为failed
  • 第三方插件:pytest-html

Pytest测试报告示例

1、JunitXML格式的测试报告
  • JunitXML格式的报告是在pytest命令后加上--junitxml=path。
  • 运行测试集中的用例:pytest -q --tb=no --junitxml='E:\python_interface_test\results\makejunitstyle.xml'
  • --tb=no是不输出traceback信息
  • 看图:4个用例失败,25个用例通过,1个用例xfailed,1个用例错误

junit.png

  • 查看生成的报告,报告路径和名称为--junitxml=之后设定的
  • 看图: 1)、testsuit中的信息包含:总运行时间、总用例数、跳过或执行不成功的用例数; 2)、testcase中的信息包括:case运行时间、case名、case所在的行数、case所在的模块名、case所在的类名; 3)、如果case有输出信息或错误信息,也会在对应的元素中显示,参见有输出或错误的用例。

xmlreport.png

2、resultlog文本格式的测试报告(预计在4.0移除)
  • 运行命令:pytest -q --tb=no --resultlog='E:\python_interface_test\results\resultlog2.txt'

resultlog.png

  • 查看结果:(完全看不懂,不要关注这种生成方式了)

logreport.png

3、url格式的测试报告
  • url格式的报告是将测试结果发送给pastebin服务器,在用例执行完成后,生成一个url地址
  • 运行命令:pytest --pastebin=all,如果只想看失败的信息把all换成failed

url.png

  • 查看结果:输出信息和控制台中的traceback一样,只是保存在了服务器上,看起来还是比较乱

urlreport.png

4、pytest-html第三方插件生成的测试报告
  • 秉持拿来主义的精神,这个报告应该会好看一点
4.1.安装pytest-html

pytest插件的安装和卸载方式为:

pip install pytest-NAME
pip uninstall pytest-NAME

so,安装pytest-html:

python -m pip install pytest-html
4.2.pytest-html的使用

pytest-html顾名思义,生成的报告格式为html的。

  • 运行命令:pytest -q --tb=no --html=E:\python_interface_test\results\makehtml.html

html.png

  • 查看结果:结果中分为3部分,Environment、Summary、Results; 1)、在html报告中会有报告生成日期及采用的pytest-html版本; 2)、Environment:记录了运行的环境信息; 3)、Summary:描述了运行用例数、时间及用例的状态; 4)、Results:记录了每个用例的执行状态、用例名称及路径、执行时间;(ps:执行时间只精确到2位小数,所以好多用例的时间都为0)

htmlreport.png

总结

从上面的介绍中看出,JunitXML和pytest-html的可读性和可分析性更好。

  • JunitXML可用于持续集成,格式为xml;
  • pytest-html界面美观,执行信息及结果信息全面。

作者: 乐大爷 博客:https://www.jianshu.com/u/39cef8a56bf9 声明:本文已获作者授权转载,著作权归作者所有。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-04-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 开源优测 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Pytest的报告输出方式
  • Pytest测试报告示例
    • 1、JunitXML格式的测试报告
      • 2、resultlog文本格式的测试报告(预计在4.0移除)
        • 3、url格式的测试报告
          • 4、pytest-html第三方插件生成的测试报告
            • 4.1.安装pytest-html
            • 4.2.pytest-html的使用
        • 总结
        相关产品与服务
        持续集成
        CODING 持续集成(CODING Continuous Integration,CODING-CI)全面兼容 Jenkins 的持续集成服务,支持 Java、Python、NodeJS 等所有主流语言,并且支持 Docker 镜像的构建。图形化编排,高配集群多 Job 并行构建全面提速您的构建任务。支持主流的 Git 代码仓库,包括 CODING 代码托管、GitHub、GitLab 等。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档