postman接口测试工具——Chrome插件

强大的网页调试与发送网页HTTP请求的Chrome插件
一、Postman官网下载地址
二、下载安装教程
1、选择下载版本
  
2、下载完成之后,直接安装即可,无需任何操作
 
三、Postman系统教程
1、设置Postman主题:File——>Settings——>Themes
 
2、Postman基础功能介绍
 
a、collection在postman里面相当于一个文件夹,可以把同一个项目的请求放在一个Collection里方便管理和分享,Collection里面也可以再建文件夹。这里我们做一个普通接口的简单的示例:
   
     
3、请求区域介绍
 
a、 Authorization:身份验证,主要用来填写用户名密码,以及一些验签字段,postman有一个helpers可以帮助我们简化一些重复和复杂的任务,当前的一套helpers可以帮助你解决一些authentication protocols的问题。
b、 Headers:请求头部信息。
c、 Body:post请求时必须要带的参数,里面放一些key-value键值对。
d、 Pre-requerst Script: 可以让你在 请求之前自定义请求数据,这个运行在请求之前,语法使用JavaScript语句。
e、 tests:tests标签功能比较强大,通常用来写测试,它是运行在请求之后。支持JavaScript语法。postman每次执行request的时候,会执行tests。测试结果会在tests的tab上面显示一个通过的数量以及对错情况。这个后面会进行详解,它也可以用来设计用例,比如要测试返回结果是否含有某一字符串。
f、 form-data:它将表单数据处理为一条消息,以标签为单元,用分隔符分开。既可以单独上传键值对,也可以直接上传文件(当上传字段是文件时,会有Content-Type来说明文件类型,但该文件不会作为历史保存,只能在每次需要发送请求的时候,重新添加文件。),post请求里较常用的一种。
g、 x-www-form-urlencoded:对应信息头-application/x-www-from-urlencoded,会将表单内的数据转换为键值对;
h、 raw:可以上传任意类型的文本,比如text、json、xml等,所有填写的text都会随着请求发送;
i、 binary:对应信息头-Content-Type:application/octet-stream,只能上传二进制文件,且没有键值对,一次只能上传一个文件, 也不能保存历史,每次选择文件,提交;
四、导出和导入接口集(Collection)
1、导出    数据一般以postman_collection.json结尾
     
2、导入
 
五、关于设置环境变量
1、Global——全局
2、Environment——环境
3、Local——局部
4、Data——数据
优先级从高到低:Data——Local——Environment——Global
Postman支持一键切换环境
   
新增环境dome
 
将返 回值的某个数据设置为环境变量
定义一个xxx,获取body中返回的所有参数,并转化为JSON格式 var xxx = JSON.parse(responseBody);
//把json字符串转化为对象。parse()会进行json格式的检查是一个安全的函数, 如:检查json中某个数组元素的个数(这里检测programs的长度)
var data = JSON.parse(responseBody);tests["program's lenght"] = data.programs.length === 5;
将返回中的值设置为一个环境变量 pm.environment.set("key",xxx.data.value);或者postman.setEnvironmentVariable("key", "value");
将返回中的值设置为一个全局变量,        pm.globals.set("key",xxx.data.value);或者postman.setGlobalVariable("key", "value");
//注意:Global后面不能加S,value值一定要指定到某个具体节点
实际操作:
一个微信登录的接口token值获取
  
这是一个微信登录的接口,属于post方法,里面的必须参数是unionid,这里我已经把unionid填在body里了,点击send下面可以得到一个token
该登录token每次请求的值都是不一样的,属于一个动态值。而后面我们的所有接口请求都需要这个token,现在就可以使用tests将它放置在环境变量里
 
var acquiretoken = JSON.parse(responseBody);
//定义一个acquiretoken方法(获取token),把responseBody转为json字符串
pm.environment.set("token",acquiretoken.data.token);
//将token变量放置到当前环境变量里去
再次执行send后,点击右上角小眼睛
 
发现变量就储存在了dome的环境变量里,每次点击send进行请求,发现环境变量里token都会随着结果变化而变化。
同理,全局变量统一可以这样设置
在设置过变量后,调用变量的时候,在postman里也比较方便,直接使用{{变量名}}就可以了,
加入我们在body里需要一个token值,那么我们可以直接在引用在环境变量里储存的token,例如:
 
                                                    引用变量的时候会有一定的提示
 
                                        变颜色代表引入变量成功
上面的效果和下面这种把一点点输入的的效果是一样的!
 
六、其他常用的tests方法
在postman里,内置了一些常用方法,可以很方便的调用
 
测试response Headers中的某个元素是否存在 tests["元素Content-Type是否存在"] = postman.getResponseHeader("Content-Type");
//getResponseHeader()方法会返回header的值;
 
定义一个xxx,获取headers值 var.xxx = postman.getResponseHeader("key");
将Headers中的值设置为一个环境变量 postman.setEnvironmentVariable("key",xxx);或者pm.environment.set("key",xxx);
 
检查response的code值是否为200 tests["Status code is 200"] = responseCode.code === 200;
// tests["Status code is 200"]中的tests是一个内置对象,
tests["Status code is 200"]是指为这个断言起个名称叫”Status code is 200”,这个名称可以自行修改。
responseCode.code === 200中的responseCode是内置对象,responseCode对象中有个属性是code,是指HTTP状态码的code,判断code是否为200.
综合起来,这句代码的意思是:名称为”Status code is 200”的断言中,判断responseCode对象的code属性值(HTTP状态码)是否为200。
 
检查response的body中是否包含字符串 tests["Body matches string"] = responseBody.has("type");
// tests["Body matches string"]中的tests是一个内置对象,
tests["Body matches string"]是指为这个断言起个名称叫”Body matches string”,这个名称可以自行修改。
这句代码的意思是:名称为”Body matches string”的断言中判断响应正文中是否包含:type这个字段。type无论是key或者value,只要匹配就可以。多个类型可用“,”分割。
 
检查Response Body是否等于字符串 tests["测试点"] = responseBody === "Response Body返回的内容";
//这个可以用在接口返回内容为纯字符串时,直接检查整个返回结果的正确性
 
检查Response time 是否小于200ms tests["Response time 小于200毫秒"] = responseTime < 200;
 
检查Response time 是否大于200ms tests["Response time 大于200毫秒"] = responseTime > 200;
 
postman.setNextRequest('Request 4')
// postman.setNextRequest()是一个带有一个参数的函数,它是接下来要运行的请求的名称或ID。往往用来跳转至某个接口,只在运行该集合时有用,单独运行无效
 
 var jsonObject = xml2Json(responseBody);
//转换XML body为JSON对象
 
设置一个随机数变量 pm.globals.set("type",parseInt(4*Math.random())+1);
//针对不同类型的课程类型,设置一个1到4的随机整数,字段名是type,parselnt 是强制转换为整数
 
校验接口返回是否有数据 tests["获取第一个结果"] = xxx.content.jieguo[0];
//我的程序设置的是如果当前没有数据,则只返回content[],所以这句断言可以校验,如果content里还有数据,则视为返回不为空
七、使用postman进行接口自动化测试
首先,既然是自动化测试,那么我们肯定需要工具 (Postman) 或者代码能帮我们直接判断结果是否符合预期。那么在接口测试上,大体就两个思路:
判断请求返回的 code 是否符合预期
判断请求返回的内容中是否包含预期的内容(关键字)
   
 
发现,运行成功。里面我每个接口都写了两个tests进行校验字段,所以上面一共有6条tests测试点被测试到,并且是成功的
每个接口里的tests数据如下:
 
当然,如果想要每次运行不一样的数据,我们需要其他的方法,比如,使用pre-requestScprit功能,导入或者生成随机数据进行测试
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值