『德不孤』Pytest框架|『德不孤』Pytest框架 — 9、Pytest测试报告
目录
- 1、pytest-html插件
- 2、Allure测试报告
- (1)Allure框架说明
- (2)Allure框架的使用
1、pytest-html插件 Pytest可以通过命令行方式,生成
xml/html
格式的测试报告,并存储于用户指定路径。需要用到
pytest-html
插件。安装方式:执行命令
pip install pytest-html
。(1)插件使用方式:
命令格式:
--html=用户路径/report.html
运行方式:
main()
函数方式:
pytest.main(['--html=./report/report_01.html'])
(不好使,可能配置了pytest.ini
文件)- 命令行方式:
在report
目录中生成report.html
测试报告。
pytest ./pytest_demo/test_pytest_01.py --html=./report/report.html
- 使用
pytest.ini
文件方式:
在addopts
属性后追加--html
参数配置,在report
目录中生成report.html
测试报告。
addopts = -s --html=../report/report.html
在指定目录中会生成
assets
文件夹(css
文件)和report.html
文件。如下图所示:
文章图片
提示:若要生成2、Allure测试报告 (1)Allure框架说明xml
文件,可将--html=./report.html
改成--junitxml= report/report.xml
Allure
生成的测试报告与上面pytest-html
插件生成的测试报告对比,简直完美!Allure
是一个Report
框架,是一种灵活的轻量级,支持多语言的测试报告工具,它不仅能够以简洁的WEB报告形式显示已测试的内容,并带有失败用例截图、测试步骤和测试说明信息,也可以集成到Jenkins
上展示高大上的报告界面。而且允许参与开发过程的每个人从测试的日常执行中提取最大限度的有用信息。
Allure
框架支持的语言包括:Java
Python
JavaScript
Ruby
Groovy
PHP
.Net
Scala
- https://docs.qameta.io/allure/#_about
- https://github.com/allure-framework/allure-pytest
步骤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
文件)提示:步骤5:生成
- 命令行参数:
pytest --alluredir report
,是在执行命令目录生成report
文件夹,文件夹下包含xml
文件。- 将
pytest.ini
文件中的生成报告的命令替换成--alluredir report
,在命令行中运行pytest
即可生成报告格式为Json
格式,保存在项目文件的report
文件夹中。
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
测试报告如下图:文章图片
【『德不孤』Pytest框架|『德不孤』Pytest框架 — 9、Pytest测试报告】提示:Allure
测试报告支持自定义修改。
推荐阅读
- 『现学现忘』Docker基础|『现学现忘』Docker基础 — 11、Docker安装的问题补充
- 『现学现忘』Docker相关概念|『现学现忘』Docker相关概念 — 6、虚拟化技术分类
- 『现学现忘』Docker相关概念|『现学现忘』Docker相关概念 — 4、虚拟化概念
- 『现学现忘』Docker相关概念|『现学现忘』Docker相关概念 — 3、IaaS、SaaS、PaaS服务模式补充
- 『现学现忘』Docker相关概念|『现学现忘』Docker相关概念 — 2、云计算的服务模式
- 『无为则无心』Python日志|『无为则无心』Python日志 — 65、日志模块logging的使用
- 『无为则无心』Python基础|『无为则无心』Python基础 — 63、Python中的生成器
- 一文搞懂Go|一文搞懂Go Exec 僵尸与孤儿进程
- 云数据管理将会打破存储孤岛和团队孤岛
- 『无为则无心』Python面向对象|『无为则无心』Python面向对象 — 59、魔法方法