先描述下,在没有jenkins的情况下,如何用allure生成测试报告的.

前置条件  安装allure,将allure\bin配置到环境变量中。allure是依赖java的,所以要先安装好java环境

生成html的步骤 

1、先生成json文件

执行命令:pytest.main(["-sq", "test_sample.py" ,'--alluredir=report']) 其中参数--alluredir=report是指在当前目录下面新建一个report目录,生成json文件存储在report里面

2、将json文件生成html文件 执行 allure generate report/ -o report/html
其中的report/ 为生成的json路径, report/html是在report下生成一个html文件夹,里面存储有最终的测试结果,这里用的都是相对路径,也可以用绝对路径来生成.

生成的结果可以到html文件夹里面查看,这里有个坑,用chrome打开的时候,可能会没数据,但是换成火狐就可以正常显示,还不清楚为什么.

Jenkins嵌入式软件单元测试工具_绝对路径

 

接下来就是在jenkins中使用allure生成自动化测试结果了.

首先是安装对应的插件allure-jenkins-plugin  HTML Publisher plugin 在系统管理--插件管理里面

接下来安装allure的执行工具 https://github.com/allure-framework/allure1/releases/download/allure-core-1.5.2/allure-commandline.zip,下载后今日系统管理---global_tool_configuration,配置allure commandline

Jenkins嵌入式软件单元测试工具_绝对路径_02

接下来开始配置job,新建一个new item

Jenkins嵌入式软件单元测试工具_json_03

2/配置item

先修改use custom wrokspace ,方便后续allure读取生成的json.以及从json生成html.,这里我配置的是脚本的文件夹路径

Jenkins嵌入式软件单元测试工具_json_04

我的脚本文件的格式如下:

Jenkins嵌入式软件单元测试工具_html_05

后续需要用到的test_sample.py在配置的workspace下.

3/配置构建脚本,这里的脚本是要执行的测试任务,以及生成allure需要的json文件,为了方便理解,我直接都用了绝对路径,执行前面的任务

Jenkins嵌入式软件单元测试工具_Jenkins嵌入式软件单元测试工具_06

--alluredir d:\django_project\p3_tongtool\report12  report是一个文件夹,存放生成的json文件

后面的exit 0 是为了方便脚本退出,不加的话,构建的过程中会提示错误.

Jenkins嵌入式软件单元测试工具_绝对路径_07

4/最后的任务就是把批处理生成的json 生成配置allure,根据前面的执行命令 allure generate report/ -o report/html ,我们需要知道存放json的路径,还要指定一个存放生成html的文件夹.带着这个思维,我们看下jenkins下关于allure的配置.

Jenkins嵌入式软件单元测试工具_Jenkins嵌入式软件单元测试工具_08

点击advanced,展示allure report的配置

Jenkins嵌入式软件单元测试工具_html_09

以上的配置,就是最后将json转化为html的时候,将结果存放于%workspace%/allure-report1文件夹了

Jenkins嵌入式软件单元测试工具_Jenkins嵌入式软件单元测试工具_10

点击保存,配置完毕.

然后执行构建.看来输入的日志

Jenkins嵌入式软件单元测试工具_json_11

可以看到,输入的日志中,操作步骤和pytest+allure中的一致,唯一的区别只是allure的操作在jenkins中集成了.

 

最后可以看下jenkins中输出端 结果

Jenkins嵌入式软件单元测试工具_Jenkins嵌入式软件单元测试工具_12

在jenkins中的结果,比较python+allure的结果,多了一个trend的结果,在jenkins中,可以持续展示构建的结果趋势.

这样就可以在jenkins中,通过构建,来执行自动化测试了,再配置触发自行的条件,就能实现持续构建了,这块后续补充.