前言
自动化测试结果都需要有个报告来展示,常用的报告有HTMLTestRunner,pytest-html,Allure。这三种报告各有不同,本文主要介绍如何通过python来生成Alluer报告
Allure
Allu属于一种开源的测试框架,可以基于多种语言进行使用,如java的junit,python的pytest。alluer生成的报告内容比较美观,目前测试中常用的测试报告。Allure的环境是基于java环境的,前提条件需要将java的环境安装完成。(下载JDK,配置环境变量。)
下载地址:https://github.com/allure-framework/allure2
E:\>allure --version 2.13.1
由于我们是通过pytest进行生成alluer报告的,也需要进行安装alluer在pytest中的第三方插件allure-pytest
安装插件: pip install allure-pytest
编写用例
按照pytest的用例格式,编写几个测试用例
import pytest class TestCase: def test_01(self): print('---用例01---') assert 1 def test_02(self): print('---用例02---') assert 1 def test_03(self): print('---用例03---') assert 0 if __name__ == '__main__': pytest.main(['-s'])
生成报告
在执行用例的时候,需要输入一些命令,才能生成allure报告
--alluredir ./report/result # 其中./report/result表示将生成的报告存放目录
注意:这里通过allure-pytest只是帮助我们将测试结果创建出来,但是无法生成HTML格式且生成的测试数据不会清空,而是以追加的形式。
执行完成上述命令,可以看到在当前目录中生成了report文件,文件下展示的有一些json文件,这些文件属于我们执行的测试结果内容。
想要生成对应的测试报告,需要再次在终端中输入对应命令
方法一:
allure generate 生成测试结果数据 -o 生成报告的路径 --clean # --clean表示:如果已经存在生成报告路径文件夹时,再次使用会提示添加--clean参数来重写 # 如以下编写用例命令 allure generate report/result/ -o report/html --clean
allure open 生成报告的路径地址 E:\auto_test\test_01>allure generate report/result/ -o report/html --clean Report successfully generated to report\html # 这样就会自动打开allure报告信息
方法二:
E:\auto_test\test_01>allure serve report/result Generating report to temp directory... Report successfully generated to C:\Users\HAIYAN~1\AppData\Local\Temp\6715359970756727599\allure-report Starting web server... # 命令中allure serve 表示确定一个allure的服务,后面跟的是报告的路径内容