Postman使用详解

Posted zhufeng123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Postman使用详解相关的知识,希望对你有一定的参考价值。

一、概念

  1、Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件,Postman分为Postman native app和Postman Chrome app两个版本。目前Chrome app已经停止维护,官方也不推荐使用该版本。

  2、官网下载地址:http://www.getpostman.com

  3:官方文档:http://www.getpostman.com/docs

二、基础测试流程

  1、第一步:新建接口集,管理所有接口

    技术图片

  2、第二步:新建接口请求

    技术图片

  3、第三步:填写相应参数,添加断言

    技术图片

   4、第四步:运行接口集

    技术图片

  5、第五步:得到用例结果

    技术图片

 三、接口请求方式

  1、get请求:点击Params,输入参数及value,可输入多个,即时显示在URL链接上

    技术图片

  2、POST请求:

    1)参数格式

      技术图片

    2)二进制文件提交:

      技术图片

    3)可以直接使用快捷方式将body或者params数据导入

      技术图片

四、设置变量与测试沙箱

  1、环境变量

    技术图片

     1)第一步:创建 Environment 变量

      技术图片

    2)第二步:调用Environment变量,调用参数方式是:{{变量名称}}

      技术图片

   2、全局变量

    技术图片

     1)创建Globals变量

      技术图片

     2)调用Globals变量

      技术图片

   3、测试沙箱

    1)Postman测试沙箱其实是结合JS脚本完成测试中的功能,在请求发起前后实现部分测试操作。

    2)常用功能:请求前脚本( pre request scripts )设置请求前置操作如设置变量等。

                请求后对状态码、响应头、响应正文等信息进行断言操作。

    技术图片

    技术图片

    技术图片

五、断言

   1、概念:断言就是对预期结果与实际结果的判断,预期==实际,就通过;预期!=通过则失败

  2、Postman的断言是javascript语言编写的,写在tests标签页里,在sandbox中运行

  3、常见断言:可参考:https://www.cnblogs.com/suim1218/p/8931159.html

    1)Get an environment variable (获取环境变量)

    2)Get a global variable (获取一个全局变量)

    3)Response body:contains string (检查响应主体是否包含字符串)

    4)Response body:is equal to a string (检查响应主体是否等于一个字符串)

  4、Json断言

    1)编写JS语句:判断返回的结果中city值是否正确

var 变量名 = JSON.parse(responseBody);
tests["标题"] = 变量名.键名 === "值"

      技术图片

var 变量名 = JSON.parse(responseBody);
tests["标题"] = 变量名.列表名[0].键名 === "值"

    判断data列表中第一个元素data的值是否正确

    技术图片

     2)调用postman方法

      a、判断返回的结果中city值是否正确

        技术图片

       b、判断data列表中第一个元素data的值是否正确

        技术图片

   5、参数化断言:基本格式:data.变量名

    技术图片

六、测试集与数据驱动

  1、测试集的使用:为了更方便地管理接口请求的执行,可以通过postman 测试集(collection)来完成测试的操作,每一个测试请求可以看成一个测试用例(testcase),

collections能够一次管理多个测试用例来执行。通过save,能够将请求保存到collections中使用。

    技术图片

   2、数据驱动:当需要进行数据驱动方式运行多次Postman脚本时,可以通过csv文件或者json格式的文件对接口测试数据进行管理,以方便用例管理执行。

    在接口请求中,参数使用变量名获取,之后在创建数据文件时,使用这些变量名编辑测试数据。在测试沙箱中,参数的获取用data.参数名的形式来进行读取。

    技术图片

  3、当需要进行数据驱动方式运行多次Postman 脚本时,可以通过csv文件或者json格式的文件对接口测试数据进行管理,以方便用例管理执行。

    1)创建测试数据:创建一个csv格式文件之后,通过notepad++或者excel进行编辑。

      注意:文件需要使用UTF-8编码,创建了csv文件之后,在notepad++中使用编码菜单中的转为UTF-8编码功能将文件转为UTF-8编码使用。

         文件中第一行必须是接口请求使用的变量名,后续每行填写本次执行使用的变量值。

      技术图片

     2)使用测试数据文件

      在collection runner中data选项选择编辑好的测试数据文件,preview能够查看文件预览,确保文件读取内容无误。

      技术图片

七、Postman持续集成

  1、安装nodejs

    1)下载地址: http://nodejs.cn/download/

    2)安装之后确认环境变量中已经添加了node所在目录,否则手动添加。在cmd中通过node v和npm v命令确认node环境已经搭建成功

    技术图片   

  2、安装newman:通过newman来执行postman测试脚本,并生成测试报告

    1)npm install -g newman --registry=https://registry.npm.taobao.org

      技术图片

     2)newman -v 查看版本,检测是否安装成功

  3、安装html报告:npm install -g newman-reporter-html

    技术图片

   4、Newman执行测试

    1)从Postman导出测试集合

     技术图片

    2)Newman执行collection导出的Json文件

      命令行中输入newman run导出的Json文件名通过Newman命令行运行测试集

     技术图片

  5、Newman常用参数

    1)-e,--environment:使用环境变量文件或url

        使用时,首先在环境变量中通过导出功能将环境变量导出,然后用如下命令引用。

     技术图片

    2)-g, --global:使用全局变量文件或url

     类似环境变量使用,在使用前,先导出全局变量文件,再通过g指定文件使用

    3)-d, --iteration-data:指定使用的数据驱动文件

        技术图片

    4)-n:指定测试集循环次数iterations

        技术图片

  6、Newman生成测试报告

     Newman提供的测试报告中,常用的包括cli、json和html三种格式,可以通过-r或者--reporter命令指定所用格式

    1)cli格式为在 cmd 客户端呈现的报告模板, newman 默认使用该格式。

    2)json格式可以导出json格式的报告,通过-r json进行设置,并加上--reporter-json-export参数指定报告生成的路径。

       技术图片

     3)html格式可以导出html格式的报告,通过-r html进行设置,并加上--reporter-html-export参数指定报告生成的路径。

      在使用之前需要通过npm install -g newman-reporter-html先完成安装。

      技术图片

   7、定时任务执行脚本

    在实现了newman对测试集的命令行运行之后,可以通过编写ba 脚本,将其设置为windows定时任务,以完成测试脚本的定时运行。

    1)编写bat脚本

    2)设置定时任务

     在计算机上右键管理,在弹出菜单里的任务计划程序里创建定时任务配置执行。

     技术图片

     技术图片

     技术图片

     技术图片

   8、Jenkins持续集成

    1)创建自由风格项目后,在构建触发器里,配置定时构建选项,指定任务定时执行。
         五个参数分别代表 分 时 天 月 星期 的周期维度。

      技术图片

     2)在构建时,添加构建步骤选择执行windows批处理命令,将Newman命令写入即可

      注意:如果Jenkins输出中文乱码,在环境变量中,添加一个变量JAVA_TOOL_OPTIONS值为Dfile.encoding=UTF 8 ,重启Jenkins

      技术图片



以上是关于Postman使用详解的主要内容,如果未能解决你的问题,请参考以下文章

postman 自动生成 curl 代码片段

postman添加断言

PostMan——安装使用教程(图文详解)

详解--Postman基本使用方法+接口关联+[Python+requests]代码接口关联,值得你收藏

postman:详解在postman中使用环境变量

Postman使用详解