目录
[6、Pre-request Script 前置脚本](#6、Pre-request Script 前置脚本)
[7、Tests 断言](#7、Tests 断言)
[1)断言响应状态码:Status code: Code is 200](#1)断言响应状态码:Status code: Code is 200)
[2)断言响应体是否包含某个字符串:Response body: Contains string](#2)断言响应体是否包含某个字符串:Response body: Contains string)
[3)断言响应体是否等于某个字符串(对象):Response body: Is equal to a string](#3)断言响应体是否等于某个字符串(对象):Response body: Is equal to a string)
[4)断言JSON数据:Response body: JSON value check](#4)断言JSON数据:Response body: JSON value check)
[5)断言响应头:Response headers: Content-Type header check](#5)断言响应头:Response headers: Content-Type header check)
前言
Postman的安装、注册、登录我在这里就不啰嗦了,小伙伴们可以自行查找资料~
对URL不熟悉的伙伴,可以先看这篇文章:http://t.csdnimg.cn/ANc4x,熟悉一下,再学习Postman的使用~
1、小白使用Postman是不是这样的?
很多的小白,对Postman的使用都只停用在如下步骤:
data:image/s3,"s3://crabby-images/fdd64/fdd64aae49f72a9ea0c7bb4a053c10bcd7e012b8" alt=""
举例:
data:image/s3,"s3://crabby-images/9055c/9055cbbc77df1e34275c6a0e5f8aee02386e0bb4" alt=""
上述都是初级使用,下面我们来学习Postman更高级的用法:
2、管理测试用例
2.1、创建用例集collections
- 1、给项目建一个文件夹,意思就是该项目的接口用例都写在这个下面:
data:image/s3,"s3://crabby-images/99f0c/99f0c95d350fb8e671a3b8dc487a1b29d2800d2d" alt=""
- 2、给项目中每个模块建一个文件夹,就是对项目下不同模块的接口进行一个分配:
data:image/s3,"s3://crabby-images/a3028/a3028aa80ccec068ed1fca7b868e545f1aa8c1e7" alt=""
data:image/s3,"s3://crabby-images/b2656/b2656d2f035544cf1f0b761077fa4d0cb10e96ac" alt=""
例如,我们这是一个用户的登录模块:
data:image/s3,"s3://crabby-images/ce8c1/ce8c19c83da71ba7a9910eb4a6a4de90d338139e" alt=""
- 3、在指定文件下,创建一个请求:
data:image/s3,"s3://crabby-images/a303b/a303b077ae636492fa929fb1a8a7f0f370660485" alt=""
例如,我们准备要写一个登录成功的接口用例测试:
取名:
data:image/s3,"s3://crabby-images/21408/21408dfc626cec51af55a96d91072ee9a347e07d" alt=""
data:image/s3,"s3://crabby-images/98edd/98eddbf02e959d706cdf4334900441f99000ce96" alt=""
3、用例集的导出导入
- 我们先来导出:
data:image/s3,"s3://crabby-images/d45f7/d45f700ec22601ce5a49ae9d75022f7cf57a292f" alt=""
注意:导出用例集时,蓝色方框的三个点是总的用例集后面的,不是请求后面的也不是模块文件夹后面的~
点击后:
data:image/s3,"s3://crabby-images/e9f95/e9f9589d8dd3f23e60e6e2d2e6ba794e7bce100d" alt=""
data:image/s3,"s3://crabby-images/7e51f/7e51f71bdbf02dd661568c2058ee724cff7f2a85" alt=""
上述的文件夹的名字,只能修改BlogSystem这个不分,后面的一长串都不可以修改~
- 导入操作:
我们可以先把刚才Postman中的用例集删除掉再进行下面的操作:
data:image/s3,"s3://crabby-images/4eedc/4eedce24ab3e1e34fb5fd7e4230b53b99593dac8" alt=""
data:image/s3,"s3://crabby-images/1d690/1d690f08e8ca58e0e9cc74c37711ac190febc9bf" alt=""
data:image/s3,"s3://crabby-images/c0d45/c0d45492529f0ad3b6a2177f89e330a953f1e989" alt=""
data:image/s3,"s3://crabby-images/ceb8e/ceb8ef03206345185c0326948cde267112d41174" alt=""
导入成功:
data:image/s3,"s3://crabby-images/13505/13505db348b5978c9b5d2522b97ed60b78e9566f" alt=""
4、再次认识Postman
说明:
- Params:参数。指的就是url后面的参数,所以我们可以在在Params中写,也可以直接在URL后面写,都可以~
- Authrization:授权。这里后面会有详细说明~
- Headers:这个就是请求的请求头部分了~
- Body:这个就是请求的请求体部分~
- Pre-request Script:这个是Postman的请求前置脚本。具体后面会有详细说明~
- Tests:Postman的断言。后面会具体介绍~
- Settings:设置相关,这个就没什么好说的~
5、Authrization授权
来看如何设置:
data:image/s3,"s3://crabby-images/01c0a/01c0a1bcd6f6ca46a79115978d305851c9c3c4c7" alt=""
这里只是一个简单的使用举例,更多的可以看这篇文章:
举例1,使用Bearer Token:
data:image/s3,"s3://crabby-images/73d55/73d55c55ccbfa9f466b855c142e66efbc7acae72" alt=""
举例2,使用Bearer Auth:
data:image/s3,"s3://crabby-images/6bfcf/6bfcfcee981624196a6795b0203f2ef6ac8d1f3e" alt=""
上述两个例子,其实都差不多,都是使用Token来实现鉴权,也就是检验用户的 身份信息是否是已登录状态~
这里根据你自己的项目来定,例如现在大部分的项目都是使用Token而不是cookie和Session。
举例1的说明:
如果是使用Token的话,这里你把Token的那串字符串放在这里即可,我们知道,Token一般是一个字符串,登录后在浏览器查看:
data:image/s3,"s3://crabby-images/7b70a/7b70a0fc465d8a1bf66030e17134aff8fa59f971" alt=""
这里是我登录我的网站(自己做的)后,存储的令牌在这里~ 这里我其实是采用最简单的处理方式来做的,过多的解释,我在这里就不说了【我这两天就会出一篇,站在开发者角度上,来处理这个Token的问题】,在这里大家就只需要理解Authorization是key,对应的value是该用户的令牌,以字符串形式呈现,格式为Bearer + " " + 唯一标识的字符串。大家在浏览器上可以把这个后面这个value字符串复制下来,不要前面的Bearer和空格,粘贴在:
data:image/s3,"s3://crabby-images/82e90/82e9073826320c441ac6e6de8feb2d54f4cc4494" alt=""
为什么不要前面的Bearer和空格?这个数据最后去哪儿?
因为在Authorization中的信息,会被自动拼接到header中,格式为:"Bearer" + 一个空格 + 刚才的字符串
我们抓包看看:
data:image/s3,"s3://crabby-images/8db9f/8db9fd534b4a98d450b93247bd9c2736f04d7059" alt=""
举例2的说明:
data:image/s3,"s3://crabby-images/a2dee/a2deec5a2001dd770479b9981d7f8cd068af0f1f" alt=""
这里的数据同样是"Bearer" + 一个空格 + 字符串。这个字符串是哪儿的?是根据你输入的这个用户名和密码以username:password的形式转为Base_64的字符串。能不能使用这个方法来获取令牌,要看你的项目后端是如何实现的~
6、Pre-request Script 前置脚本
什么是前置脚本:
在Postman中,Pre-request Script 前置脚本就是指,在你按下send按钮后,第一时间被执行的代码,为前置脚本;使用JS编写~
为什么需要这个前置脚本?
我在这里举一个特殊情况的例子:有一个接口,要求输入的时间戳的标准值不能超过标准时间的5分钟,否则给接口不能被调用~
此时如果我们直接在请求头或请求体中写死这个时间戳,那随着时间的推移,这个接口测试用例就会出错。此时就需要我们写一个前置脚本,每次在Postman真的向服务器发送请求之前都会去动态的过去时间戳,这个接口用例就不会再出错了~
data:image/s3,"s3://crabby-images/09219/092197b70b24fc0ed59604ebe17ea545f0155dcc" alt=""
这里也有Postman认为我们可能会常用的代码,如果需要直接点击,就可以生成代码,你根据自己的需求修改即可~
举例:
data:image/s3,"s3://crabby-images/04bd6/04bd6f62241e7937fb745329d18ecf6256a3b50d" alt=""
代码解读,我们继续看断言,断言中会有代码解读,看了后,这个代码什么意思就很好理解了~
7、Tests 断言
Postman中的断言:
Postman断言也是使用JS来编写的,目的就是帮助我们来判断预期结果与实际结果是否一致~
Postman中常用的断言:
1)断言响应状态码:Status code: Code is 200
data:image/s3,"s3://crabby-images/df858/df8580376604281005d9c5e197fcf5144d652844" alt=""
pm.test("Status code is 200", function () {
pm.response.to.have.status(200);
});
代码解读:
- pm:表示Postman的一个实例
- test():是Postman实例的一个方法,该方法中有两个参数:第一个参数为断言成功后给出的文字提示,这个提示可以根据自己的需求随意更改;第二个参数是一个匿名函数,这个匿名函数大致意思(根据英文猜测便可知)就是Postman实例的响应结果中应该包含状态码200
举例:
成功:
data:image/s3,"s3://crabby-images/73e30/73e300c1129d833488964f3048056723121e43cb" alt=""
data:image/s3,"s3://crabby-images/ce680/ce68019bc6240a37669d40dbf36ac763d2844a2b" alt=""
失败:
data:image/s3,"s3://crabby-images/89cf7/89cf78a58a914cec7ef06e01fedb9ba3611e0668" alt=""
2)断言响应体是否包含某个字符串:Response body: Contains string
data:image/s3,"s3://crabby-images/d4234/d42342b251ebe31cb7cb6d6f09c3e1260bdeb6db" alt=""
pm.test("Body matches string", function () {
pm.expect(pm.response.text()).to.include("string_you_want_to_search");
});
代码解读:
- 外观和上一个断言差不多哈,就不说了
- 匿名函数中大致意思:Postman的实例pm,期望 响应文本的值,包含xxx字符串
data:image/s3,"s3://crabby-images/16658/16658ef903f948007e6d7b57c9eb198eaf688df1" alt=""
例:
data:image/s3,"s3://crabby-images/43079/430798dfd7ee5d851d38a884c2f3340c6592d626" alt=""
data:image/s3,"s3://crabby-images/3c933/3c93370ac53bf04714923d84ee23064b24291d6d" alt=""
3)断言响应体是否等于某个字符串(对象):Response body: Is equal to a string
data:image/s3,"s3://crabby-images/26bab/26bab21b71f1721ab79d81dcec32bfe4a80aa4ee" alt=""
pm.test("Body is correct", function () {
pm.response.to.have.body("response_body_string");
});
代码解读:
- 外观和上一个断言差不多哈,就不说了
- 匿名函数中大致意思:Postman的实例pm,期望 响应 中应该有响应体xxx
例:
data:image/s3,"s3://crabby-images/6a896/6a89682925a5c9efda884b73f36f939daee43cd0" alt=""
data:image/s3,"s3://crabby-images/d81ca/d81ca672589e6d8d05ee85d5e2a030f57a009954" alt=""
4)断言JSON数据:Response body: JSON value check
data:image/s3,"s3://crabby-images/a370b/a370baa034a1090affdfe51194667d8c6b26f76e" alt=""
pm.test("Your test name", function () {
var jsonData = pm.response.json();
pm.expect(jsonData.value).to.eql(100);
});
代码解读:
- 外观和上一个断言差不多哈,就不说了
- 匿名函数中大致意思:第一步先是获取响应的JSON格式的结果,第二步是Postman的实例pm,期望 JSON格式的响应 中 的value对应的值 应该等于xxx
一个tips:
data:image/s3,"s3://crabby-images/63c82/63c82e805cede90d617f9365e7ccb92064cc4a4a" alt=""
例:
data:image/s3,"s3://crabby-images/caeaf/caeaf6b611a14b24caced52de0c42f7a83bd1b56" alt=""
data:image/s3,"s3://crabby-images/87550/87550236ee06271bb5adc6de3eb3f87e4a635475" alt=""
5)断言响应头:Response headers: Content-Type header check
data:image/s3,"s3://crabby-images/6ed5c/6ed5c3b2dc2b7263d7df6d0298d5a0ba222df6db" alt=""
pm.test("Content-Type is present", function () {
pm.response.to.have.header("Content-Type");
});
代码解读:
- 外观和上一个断言差不多哈,就不说了
- 匿名函数中大致意思:在响应中,响应头是否包含Content-Type 或者 断言响应头中指定key的value是否正确
例1:响应头是否包含Content-Type :
data:image/s3,"s3://crabby-images/030b1/030b15cf525b96b3fdefa31dd197309f8e3c164c" alt=""
例2:响应头中指定的key对应的value是否正确:
data:image/s3,"s3://crabby-images/66418/66418c31802c9204547535a32aa6634632349ba3" alt=""
好啦,我们今天先了解到这里,后面持续更新~