pytest+allure 酷炫的报告
首先如果你没有安装 pytest 库的话,先使用 pip 安装一下:
pip install pytest
另外还需要安装 pytest 支持 allure 报告的插件库:
pip install allure-pytest
当然这里allure这里需要下载一个离线包,配置一个全局的环境变量,配置完成后需要执行一下:
allure --version 如果显示出详细信息则已经配置成功。
2、在运行测试时,使用 pytest 命令运行:
pytest <测试目录> --alluredir <测试结果存放目录>
for example:
pytest tests --alluredir report/allure_raw
![]()
tests
为测试用例存放目录,告诉 pytest 应该去哪里找用例;report
是存放测试报告的,allure 收集 pytest 运行后产出的结果放在 allure_raw 文件夹中。
注意:这里的 allure_raw 文件夹只存放的是测试运行结果,还不是报告!报告还需要调用 allure 命令去生成。
结果是像这样的:
allure测试结果
还是一堆 txt 和 json 文件。
我们要生成漂亮的报告还需要一步,从 allure 官网上下载最新的 allure 。下载后是一个 zip 文件,把该文件解压后放到我们目录中的 lib 文件夹中。
可以把解压后的 bin 目录添加到环境变量的 PATH 中,可以直接使用 allure 命令:
![]()
allure
我们需要用到 bin 目录下的 allure 文件来生成测试报告。
命令如下:
lib\allure-2.12.1\bin> allure generate <allure测试结果目录> -o <存放报告的目录> --clean
allure测试结果目录
,是上面运行 pytest 命令后存放结果的地方,我们这里的目录是 report 下的allure_raw
文件夹;存放报告的目录
,是最终生成的测试报告存放的目录,我打算把生成出的报告放在 report 下的allure_report
文件夹中;--clean
参数用来清空已有的报告,避免覆盖时出错。
以我们的例子来生成报告的命令如下:
lib\allure-2.12.1\bin> allure generate report/allure_raw -o report/allure_report --clean
通过上面的命令运行后,就会从 allure_raw 目录中将 pytest 运行的结果生成一个漂亮的报告,存放在 allure_report 中。
allure 报告
然后在 pycharm 中可以通过右键选择index.html
就可以看到报告了。
右键浏览器打开
如果你不是用 Pycharm 的话,可以通过 allure 命令生成服务,然后查看。
>allure open /report/allure_report
运行后会启动一个 web 服务,用于展示报告:
启动一个服务来展示报告
实际跑自动化用例的时候呢,可以和 Jenkins 结合后在 Jenkins 中查看报告。
当然上面的命令很杂,我封装了一个函数,把 pytest 常用的几个插件的用法都加进去了。
pytest-xdist
多并发运行,保证测试用例的运行效率。 参数为-n 并发数
,如果并发数为auto
,表示自动根据当前机器的 CPU 内核数量确定并发数;pytest-rerunfailures
测试用例出错后,自动重试。在实际测试过程中,很多时候用例失败可能是因为网络问题,临时的环境问题,而并非真正的 Bug。为了减少(注意是减少不是避免)这种乌龙情况的发生,可以多运行几次用例。参数为--reruns 重试次数
。