Postman Day2-项目实战,硬核来了
ztj100 2025-05-24 18:21 16 浏览 0 评论
1、postman从接口调试到自动化测试:
1、自动判断执行是否成功。 -通过代码 来进行结果的断言。
2、多个接口如何批量运行。 -通过 postman的 collection 进行运行。
3、测试数据管理方式
4、工作中如何定时执行或者将自动化测试结合到研发体系中。
2、Postman断言:
1、想清楚断言的标准是什么,断言的对象是什么。
断言什么? 返回内容
返回行: 状态码
返回头: 可以携带某些信息 一般很少关注。
返回体: 验证重点是返回体。
2、postman 里 怎么完成断言:
tests菜单(其实是执行请求之后,得到返回了再执行的内容)中,编写断言脚本。
1、在tests编辑中,用//表示注释,是不执行的代码,说明文字。
可以用 ctrl+/ 快速注释一行。
2、常用的断言模板:
Status Code:Code is 200 断言返回状态码是200
Response Body:Contains string 断言返回体包含某个字符串
Response Headers:Content-Type header check 断言返回体中的头域信息
// 判断返回的状态码是否为200的测试
pm.test("返回的状态码是否为200", function () {
// function中的内容是真正执行的判断操作。
pm.response.to.have.status(200);
});
// 判断返回头中的内容。
pm.test("返回头有内容", function () {
pm.response.to.have.header("Access-Control-Allow-Metho");
});
// 表示判断返回体包含一个字符串
pm.test("返回体中包含成功", function () {
//返回中的文本内容
pm.expect(pm.response.text()).to.include("成功");
});
最常用的:
Response Body:JSON value check 断言返回结果json中的字段值
// 判断返回体和指定内容完全相等。
//注意:使用body的时候,获取到的是原始格式字符串的内容,中文等特殊字符以unicode编码呈现,所以断言的预期结果中,也要写unicode编码,记得用\\u来转义\u,否则postman依然会认为这是中文。
pm.test("返回内容是正确的", function () {
pm.response.to.have.body('{"code": 1000, "msg": "\\u606d\\u559c\\u60a8\\u767b\\u5f55\\u6210\\u529f", "data": [{"id": 12, "username": "roy", "pwd": "******", "nickname": "roy\\u8001\\u5e08", "gender": "\\u7537", "dept": "\\u6d4b\\u8bd5\\u90e8\\u95e8", "position": "\\u81ea\\u52a8\\u5316\\u6d4b\\u8bd5"}]}');
});
//验证code结果为1000
pm.test("code结果为1000", function () {
//将返回结果转为json格式,赋值给变量(variable) jsonData
var jsonData = pm.response.json();
// eql是equal 相等
//jsonData.msg表示 在json根层级中,获取msg键的内容
//1000是个数字,所以直接写。
pm.expect(jsonData.code).to.eql(1000);
});
//验证msg结果为登录成功
pm.test("msg结果为登录成功", function () {
//将返回结果转为json格式,赋值给变量(variable) jsonData
var jsonData = pm.response.json();
// eql是equal 相等
//jsonData.msg表示 在json根层级中,获取msg键的内容
//恭喜您登录成功是个字符串,所以用""引起来
pm.expect(jsonData.msg).to.eql("恭喜您登录成功");
});
//验证nickname是roy老师
pm.test("nickname是roy老师", function () {
var jsonData = pm.response.json();
//将字符串进行拼接,输出到console控制台。
console.log("data值的是:"+jsonData.data)
console.log(jsonData.data)
console.log("data中的第一个值是:"+jsonData.data[0])
console.log(jsonData.data[0])
console.log("data中的第一个值的nickname的值是"+jsonData.data[0].nickname)
pm.expect(jsonData.data[0].nickname).to.eql("roy老师");
});
3、json格式:是js中用于描述对象的语言。
有标准的格式规范:{"键":值,"键":值}
json中的值的可选项是:
- 数字或者布尔数true/false: 不用带双引号
- 字符串: "内容" 要被双引号括起来。
- 数组: [值,值,值]:比如:[1,2,3] 或者 ["roy","will"]
- json子串: {"键":值,"键":值}
js中json解析核心语法符号:
.号 :表示往下进行一层选取。
[]: ["键"]表示取某个键的值
[数字]表示取数组中的对应下标的值
js里面可以用两种方式来解析json中某个键的值:
jsonData.键: 获取json根层级下的某个键的值。
jsonData["键"]:如果键中有一些特殊字符的时候用这种方式
如果要解析数组中的第n个值: 注意编程语言中,下标从0开始计数。
jsonData.数组键[n-1]
例如:jsonData.data[0]
如果要解析一个子json中的键:
jsonData.子json键.键名
例如:jsonData.data[0].nickname
4、正则表达式解析: 通过某种规则,从字符串中获取对应的内容。
js中的正则表达式写法是 : /正则表达式/ 用//把正则表达式括起来。
例子:
//首先提取出来json内容
//编写正则表达式
//<return>(.*?)<\/return> 其中\/表示用\对/进行转义操作
//(.*?) 表示要获取的内容。
var regex=/<return>(.*?)<\/return>/
//用正则表达式获取返回结果中的内容
var result= regex.exec(pm.response.text())
//匹配出来包含两部分,一部分是有(.*?)以外的规则的内容
//另一部分是只有(.*?)的内容,注意这是字符串,不是json
console.log(result[1])
//将普通字符串,处理为json格式。
var jsonData=JSON.parse(result[1]);
//断言的时候要用的,是已经经过层层解析的jsonData
console.log(jsonData)
pm.test("返回结果msg是success", function () {
pm.expect(jsonData.msg).to.eql("success");
});
5、postman中进行调试:
console.log(内容)可以将指定内容输出到console控制台。
console控制台在postman的左下角。
同时console中可以看到postman发出去请求的具体信息,相当于给发包过程抓了个包。
6、postman 测试集collection 运行:
记得勾上 save responses ,方便查看运行的返回结果具体状态。
7、保持登录状态,进行接口的测试:
项目中进行登录鉴权的机制:
1、cookie机制
Cookie 用于服务器对用户的状态进行记录。
cookie 和session :
cookie和session 都是由服务器生成的。
session(酒店入住记录)保留在服务器上,cookie(房卡)会由服务器通过返回头中的Set-Cookie返回给客户端,由客户端保存在本地。
下次进行请求的时候,客户端在请求头中通过Cookie头携带cookie去请求服务器的接口。
cookie机制保持登录状态,核心是带上cookie:
1、尝试带上已有的cookie来进行访问(把别人的房卡直接拿来用),不一定靠谱
postman中添加头域,直接在Headers中填写键值对即可。
2、借助postman自动保存cookie的机制,先去登录(自己办一张房卡),然后请求其它接口(拿自己的房卡去房间)
postman要做的事情就是,
1、先调用一下登录接口,让postman自动保存cookie
2、然后再调用其它接口。
注意postman中cookie的管理在这里。
如果使用的是cookie机制,用postman会自动保存各种网站的cookie,和浏览器一样。
调用一下登录接口之后,就不需要额外操作就可以请求登录后的接口
2、token机制
8、postman中的环境变量/全局变量。
变量就类似于在手机通讯类 为电话号码建立一个联系人。
1、方便于进行修改
2、重复使用的时候,可以更简略。
3、方便别人进行使用 参数关联。
环境变量是创建一组变量进行分组,可以有选择性地使用。
全局变量是大家都可以用的变量。
Postman中使用环境变量:
创建环境变量组:相当于创建一个通讯录。
创建一个变量:相当于加个联系人。
使用变量:
选择环境变量组之后,在请求中,可以用{{变量名}}来使用组中的环境变量。
作业:
1、cookie和session机制中,以下描述正确的是:
A、cookie由客户端生成、session由服务端生成
B、cookie由服务端生成,发送给客户端保存在本地
C、cookie和session都保存在服务器端
D、session由服务端生成,并发给客户端保存在本地
2、json格式中,值的类型需要带双引号的是:
A、子Json
B、数字
C、数组
D、字符串
3、在postman中,可以在_______中查看脚本输出调试信息,以及查看postman请求的实际详情。
4、postman中,如何创建并在请求中使用环境变量?
5、实操题: 1、为百度ip接口编写断言,实现location字段的校验。
2、对特斯汀自动化测试平台中的部分接口抓包进行测试,并用测试集运行。
特斯汀自动化测试平台访问地址:
http://39.108.55.18/mypro/#/login
不懂的的问题评论区留言,我来回答。
相关推荐
- 这个 JavaScript Api 已被废弃!请慎用!
-
在开发过程中,我们可能会不自觉地使用一些已经被标记为废弃的JavaScriptAPI。这些...
- JavaScript中10个“过时”的API,你的代码里还在用吗?
-
JavaScript作为一门不断发展的语言,其API也在持续进化。新的、更安全、更高效的API不断涌现,而一些旧的API则因为各种原因(如安全问题、性能瓶颈、设计缺陷或有了更好的替代品)被标记为“废...
- 几大开源免费的 JavaScript 富文本编辑器测评
-
MarkDown编辑器用的时间长了,发现发现富文本编辑器用起来是真的舒服。...
- 比较好的网页里面的 html 编辑器 推荐
-
如果您正在寻找嵌入到网页中的HTML编辑器,以便用户可以直接在网页上编辑HTML内容,以下是几个备受推荐的:CKEditor:CKEditor是一个功能强大的、开源的富文本编辑器,可以嵌入到...
- Luckysheet 实现excel多人在线协同编辑
-
前言前些天看到Luckysheet支持协同编辑Excel,正符合我们协同项目的一部分,故而想进一步完善协同文章,但是遇到了一下困难,特此做声明哈,若侵权,请联系我删除文章!若侵犯版权、个人隐私,请联系...
- 从 Element UI 源码的构建流程来看前端 UI 库设计
-
作者:前端森林转发链接:https://mp.weixin.qq.com/s/ziDMLDJcvx07aM6xoEyWHQ引言...
- 手把手教你如何用 Decorator 装饰你的 Typescript?「实践」
-
作者:Nealyang转发连接:https://mp.weixin.qq.com/s/PFgc8xD7gT40-9qXNTpk7A...
- 推荐五个优秀的富文本编辑器
-
富文本编辑器是一种可嵌入浏览器网页中,所见即所得的文本编辑器。对于许多从事前端开发的小伙伴来说并不算陌生,它的应用场景非常广泛,平时发个评论、写篇博客文章等都能见到它的身影。...
- 基于vue + element的后台管理系统解决方案
-
作者:林鑫转发链接:https://github.com/lin-xin前言该方案作为一套多功能的后台框架模板,适用于绝大部分的后台管理系统(WebManagementSystem)开发。基于v...
- 开源富文本编辑器Quill 2.0重磅发布
-
开源富文本编辑器Quill正式发布2.0版本。官方TypeScript声明...
- Python之Web开发框架学习 Django-表单处理
-
在Django中创建表单实际上类似于创建模型。同样,我们只需要从Django类继承,则类属性将是表单字段。让我们在myapp文件夹中添加一个forms.py文件以包含我们的应用程序表单。我们将创建一个...
- Django测试入门:打造坚实代码基础的钥匙
-
这一篇说一下django框架的自动化测试,...
- Django ORM vs SQLAlchemy:到底谁更香?从入门到上头的选择指南
-
阅读文章前辛苦您点下“关注”,方便讨论和分享,为了回馈您的支持,我将每日更新优质内容。...
- 超详细的Django 框架介绍,它来了!
-
时光荏苒,一晃小编的Tornado框架系列也结束了。这个框架虽然没有之前的FastAPI高流量,但是,它也是小编的心血呀。总共16篇博文,从入门到进阶,包含了框架的方方面面。虽然小编有些方面介绍得不是...
- 20《Nginx 入门教程》使用 Nginx 部署 Python 项目
-
今天的目标是完成一个PythonWeb项目的线上部署,我们使用最新的Django项目搭建一个简易的Web工程,然后基于Nginx服务部署该PythonWeb项目。1.前期准备...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)
- vmware17pro最新密钥 (34)
- mysql单表最大数据量 (35)