Pytest框架 —— Pytest测试报告

1229 篇文章 11 订阅
682 篇文章 3 订阅

(1)pytest-html插件

Pytest可以通过命令⾏⽅式,⽣成xml/html格式的测试报告,并存储于⽤户指定路径。

需要用到pytest-html插件。

安装⽅式:pip install pytest-html

插件使用方式:

命令格式:--html=⽤户路径/report.html

运⾏⽅式:

  1. main()函数方式:

    pytest.main(['--html=./report/report_01.html'])(不好使,可能配置了pytest.ini文件)

  2. 命令行方式:

    在report目录中生成report.html测试报告。

    pytest ./pytest_demo/test_pytest_01.py --html=./report/report.html

  3. 使用pytest.ini文件方式:

    addopts属性后追加--html参数配置,在report目录中生成report.html测试报告。

    addopts = -s --html=../report/report.html

执⾏结果:

在指定⽬录中会⽣成assets⽂件夹(css文件)和report.html⽂件

提示:若要⽣成xml⽂件,可将--html=./report.html改成--junitxml= report/report.xml

(2)Allure测试报告

1)Allure框架说明:

Allure生成的测试报告与上面pytest-html插件生成的测试报告对比,简直完美!

Allure是一个Report框架,是一种灵活的轻量级,支持多语言的测试报告工具,它不仅能够以简洁的web报告形式显示已测试的内容,并带有失败用例截图、测试步骤和测试说明信息,也可以集成到Jenkins上展示高大上的报告界面。

而且允许参与开发过程的每个人从测试的日常执行中提取最大限度的有用信息。

Allure框架支持的语言包括:

  • Java
  • Python
  • JavaScript
  • Ruby
  • Groovy
  • PHP
  • .Net
  • Scala

Allure帮助文档

2)Allure框架的使用

步骤1:下载Allure框架,并配置到环境变量中

Allure框架下载地址:https://github.com/allure-framework/allure2/releases

然后解压Allure框架文件,放到自己指定的目录中。

把Allure框架的bin目录配置到Path环境变量中。

步骤2:验证Allure框架是否安装成功

使用命令:allure --version

需要在CMD命令行和PyCharm的Terminal中,都需要验证一下。

因为CMD可以验证通过,但是PyCharm中验证失败,如下:

J:\PyCharmWorkSpace\Pytest_d>allure --version
'allure' 不是内部或外部命令,也不是可运行的程序
或批处理文件。

解决:需要重启PyCharm。

步骤3:下载allure-pytest库(插件)

执行安装命令:pip install allure-pytest

步骤4:设置生成的Json格式临时报告的存放位置。

配置pytest.ini文件,在pytest.ini全局配置文件中的addopts属性中添加:

--alluredir ../report/temp_jsonreport

例如:addopts = -vs --alluredir ../report/temp_jsonreport

然后我们执行测试用例就可以了,当然--alluredir参数也可以不配置在pytest.ini文件,比如在执行测试的命令行或者mian()函数中填写都可以。(主要是生成Json格式的测试报告,是多个json文件)

提示:

  • 命令⾏参数:pytest --alluredir report,是在执⾏命令⽬录⽣成report⽂件夹,⽂件夹下包含xml⽂件。
  • pytest.ini文件中的生成报告的命令替换成--alluredir report,在命令行中运行pytest即可生成报告格式为json格式,保存在项目文件的report文件夹中。

步骤5:生成Allure测试报告

原理是:使用第一步下载的Allure框架把Json格式的测试报告,转换成精美的HTML测试报告。

将上面/report/temp_jsonreport文件夹中的json格式的测试报告转化为HTML格式的测试报告。

执行命令:allure generate ./report/temp_jsonreport -o ./report/html --clean

注意:以执行命令的目录为相对路径。

说明:

  • allure generate: 固定命令。
  • ./report/temp_jsonreport:生成的Json格式的临时报告的路径。
  • -o:输出output。
  • ./report/html:生成的Allure报告的路径。
  • --clean:清空./report/html路径中原来的Allure测试报告。

提示:main()函数中执行如上命令

if __name__ == '__main__':
    pytest.main()
    os.system("allure generate ./report/temp_jsonreport -o ./report/html --clean")
    
# 或者直接用main函数调用,哪种方式都可以。
# (直接执行测试文件, 而不用pytest的方式执行,就可以执行)
pytest.main(["testCase_demo1.py","-sv","--alluredir","../report/temp_jsonreport"])
os.system("allure generate ./report/temp_jsonreport -o ./report/html --clean")

说明:找不到路径的话,可以在Python Console窗口调试。

最后:生成的Allure测试报告如下图:

提示:Allure测试报告支持自定义修改。 

END绵薄之力

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

加入我的软件测试交流群:110685036免费获取~(同行大佬一起学术交流,每晚都有大佬直播分享技术知识点)

软件测试面试小程序

被百万人刷爆的软件测试题库!!!谁用谁知道!!!全网最全面试刷题小程序,手机就可以刷题,地铁上公交上,卷起来!

涵盖以下这些面试题板块:

1、软件测试基础理论 ,2、web,app,接口功能测试 ,3、网络 ,4、数据库 ,5、linux

6、web,app,接口自动化 ,7、性能测试 ,8、编程基础,9、hr面试题 ,10、开放性测试题,11、安全测试,12、计算机基础

获取方式 :

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值