第七篇 Postman+Node.js+Newman+Jenkins实现自动化测试

今天终于不咋忙了,学习整理一下一直想作却没实现的事儿,这事已经折磨团队半年之久了。由于项目是B端业务的测试,测试过程当中须要生产大量的测试数据,并且都是跨多个系统的测试,对于后置流程的测试,这些同窗每每要想有一条测试数据,就要自个去一步步的操做前置流程,最关键的是太耗时间,一条数据可能要花掉1个小时左右,加上测试环境常常不问题,1小时没了,结果测试数据也无效了。头疼吧,你也常常遇到吧。好,下面就经过Postman+Newman+node+Jenkins实现自动化测试,顺便生成测试数据吧。html

一. Postman里须要干的事node

 1. 将须要的测试接口整理到collections里,最好建立成文件夹的形式git

        

 2. 测试用例编写,断言等等都请参考个人postman系列文章github

 3. 将须要执行的接口导出存放到本地npm

    

4. 大部分业务流程都须要进行各类参数化或者接口之间有数据依赖,最好的方式也是经过设置环境变量或者全局变量的方式实现,因此若是设置环境变量,也须要将环境变量导出存放到本地json

     

导出后存放到本地:网络

           

 二. Node.jspost

Node.js是干啥的嘞?由于安装newman须要先安装Node.js学习

安装帮助文档:https://nodejs.org/en/download/package-manager/测试

下载版本:https://nodejs.org/en/#download

安装并配置环境变量:

  

 三. Newman

Newman是为Postman而生,专门用来运行Postman编写好的脚本。此Newman,非彼Newman,纽曼音乐播放器。

官方帮助文档:https://www.npmjs.com/package/newman#getting-started

Newman安装步骤:

  1. 打开控制台cmd,运行:npm install -g newman
  2. 检测是否安装成功:newman --version
  3. 配置环境变量

    

  4. 由于多数状况下,为了更好的看到测试结果,通常会输出HTML格式的报告,因此也要安装:newman-reporter-html

  newman-reporter-html 安装及用法官方参考文档:https://github.com/postmanlabs/newman-reporter-html#readme

  cmd命令:npm install -g newman-reporter-html

Newman 执行脚本:

  newman run 后面跟上要执行的json文件或者URL(json 和 URL 都由postman导出生成),后面跟一些参数,例如环境变量,测试报告,接口请求超时时间等等。

  常见命令: 
    run 运行newman的命令 
    -e 加载环境变量的数据 
    -g 加载全局变量的数据 
    -n case运行次数,默认运行次数为1次 
    –folder 运行collection中的指定folder 
    --reporters html,junit 指定生成报告的类型 
    其它命令可在github上查看: https://github.com/postmanlabs/newman#configuring-reporters 

  本地cmd执行示例命令:

   newman run E:\xiaomada\buyEensure.postman_collection.json -e E:\xiaomada\xiaomada_uat.postman_environment.json --reporters html --reporter-html-export E:\xiaomada\result.html

   

示例解析:

  newman run:运行newman的命令

  E:\xiaomada\buyEensure.postman_collection.json:要运行的接口,就是再postman里导出的collections(这里写全路径哦)

  -e E:\xiaomada\xiaomada_uat.postman_environment.json:要加载的环境变量,也是postman部分导出的数据

  --reporters html  或者 -r html:表示报告结果是html格式

  --reporter-html-export E:\xiaomada\result.html:表示导出报告格式是html的报告 到E:\xiaomada\目录下面,报告名字是result.html

固然,能够根据本身的实际须要生成JSON格式,cli格式,均可以哦,方法以下:

newman run E:\xiaomada\buyEensure.postman_collection.json -e E:\xiaomada\xiaomada_uat.postman_environment.json
--reporters cli,html,json,junit --reporter-json-export E:\xiaomada\jsonOut.json --reporter-junit-export E:\xiaomada\xmlOut.xml --reporter-html-export E:\xiaomada\htmlOut.html
红色:表示超时5s--timeout-request 5000

全部的目的都是为了解放双手,来吧,Jenkins

四.Jenkins

 既然Newman提供了控制台命令执行方式,那么经过Jenkins来构建就容易多了。

  1.安装Jenkins
     官方参考文档:https://jenkins.io/
     下载安装,傻瓜式,按照提示一步步操做就行
  2.搭建Jenkins环境,并新建个自由风格的Job
  3.构建选择Execute Windows batch command,并输入newman 运行命令
    

             

  4. 构建后操做

    由于我想用html报告展现,因此这里须要用到一个插件:Publish HTML reports,须要先安装后,才能在“构建后操做里选择”

    参考文档:https://wiki.jenkins.io/display/JENKINS/HTML+Publisher+Plugin

    简要整理安装Jenkins插件的方式:

      系统管理-->插件管理-->可选插件Tab-->找到想要的插件,勾选-->点安装按钮

   配置构html reports的步骤:

    (1)先选择Publish HTML reports,上面刚才安装的哦

            

   (2)选择后,出下图

    

    点击【新增】进行配置,在配置以后,先看下每一项的说明(转自网络)

     

    具体配置项,根据本身的需求来,我只须要下面的配置:

    

提示:我上面填写以后,最终的输出目录为%workspace%/HTMLReport/index.html

注意:这里的路径都不能使用环境变量。

注意2:这个插件不会自动按照上面的路径建立文件夹和文件,因此,必定要确保上面路径上的文件夹和文件已经在工做空间建立好,否则会出现报错。也就是说,这个插件是不建立任何html内容的。

注意3:这个插进不建立任何HTML报告,因此当你看到你的html内容时,会出现空白页。若是想要出现html的报告,能够配合一些xUnit plugin这样插件来生成html报告,而后再上面的路径中指向生成的html文件。

相关文章
相关标签/搜索