Postman Day2-项目实战,硬核来了
liuian 2025-01-04 21:27 25 浏览
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
不懂的的问题评论区留言,我来回答。
相关推荐
- Springboot 整合 Websocket 轻松实现IM及时通讯
-
一、方案实践集成分为三步:添加依赖、增加配置类和消息核心类、前端集成。1.1、添加依赖<dependency><groupId>org.springframework...
- SpringBoot扩展——应用Web Socket!
-
应用WebSocket目前,网络上的即时通信App有很多,如QQ、微信和飞书等,按照以往的技术来说,即时功能通常会采用服务器轮询和Comet技术来解决。HTTP是非持久化、单向的网络协议,在建立连接...
- 【Spring Boot】WebSocket 的 6 种集成方式
-
介绍由于前段时间我实现了一个库【SpringCloud】一个配置注解实现WebSocket集群方案以至于我对WebSocket的各种集成方式做了一些研究目前我所了解到的就是下面这些了(就一个破w...
- SpringBoot生产级WebSocket集群实践,支持10万连接!
-
1、问题背景智慧门诊系统旨在从一定程度上解决患者面临的三长一短(挂号、看病、取药时间长,医生问诊时间短)的问题。实现“诊前、诊中、诊后”实时智能一体化,整合完善医院工作流程。围绕门诊看病的各个环节,让...
- Spring Boot3 中 WebSocket 实现数据实时通信全解析
-
各位互联网大厂的开发同仁们,在如今的互联网应用开发中,实时通信功能越来越重要。比如在线聊天、数据推送、实时通知等场景,都离不开高效的实时通信技术。而WebSocket作为一种高效的双向通信协议,在...
- Java WebSocket 示例(java nio websocket)
-
一、环境准备1.依赖配置(Maven)在pom.xml中添加WebSocket依赖:xml<!--SpringBootWebSocket--><dependen...
- Spring Boot整合WebSocket:开启实时通信之旅
-
SpringBoot整合WebSocket:开启实时通信之旅今天咱们来聊聊SpringBoot整合WebSocket这件大事儿。说到实时通信,你是不是第一时间想到QQ、微信这些聊天工具?没错,We...
- Spring Boot3 竟能如此轻松整合 WebSocket 技术,你还不知道?
-
在当今互联网大厂的软件开发领域,实时通信的需求愈发迫切。无论是在线聊天应用、实时数据更新,还是协同办公系统,都离不开高效的实时通信技术支持。而WebSocket作为一种能够实现浏览器与服务器之间持...
- Spring Boot集成WebSocket(springboot集成websocket)
-
一、基础配置依赖引入<dependency><groupId>org.springframework.boot</groupId><artifactId>...
- Springboot下的WebSocket开发(springboot websocket server)
-
今天遇到一个需求,需要对接第三方扫码跳转。一种方案是前端页面轮询后端服务,但是这种空轮询会虚耗资源,实时性比较差而且也不优雅。所以决定使用另一种方案,websocket。以前就知道websocket,...
- springboot websocket开发(java spring boot websocket)
-
maven依赖SpringBoot2.0对WebSocket的支持简直太棒了,直接就有包可以引入<dependency><groupId>org....
- Python界面(GUI)编程PyQt5窗体小部件
-
一、简介在Qt(和大多数用户界面)中,“小部件”是用户可以与之交互的UI组件的名称。用户界面由布置在窗口内的多个小部件组成。Qt带有大量可用的小部件,也允许您创建自己的自定义和自定义小部件。二、小部件...
- 实战PyQt5: 014-下拉列表框控件QComboBox
-
QComboBox简介QComboBox下拉列表框,是一个集按钮和下拉列表选项于一体的部件。QComboBox提供了一种向用户呈现选项列表的方式,其占用最小量的屏幕空间。QComboBox中的常用方法...
- Python小白逆袭!7天吃透PyQt6,独立开发超酷桌面应用
-
PythonGUI编程:PyQt6从入门到实战的全面指南在Python的庞大生态系统中,PyQt6作为一款强大的GUI(GraphicalUserInterface,图形用户界面)编程框架,为开...
- 如何用 PyQt6 打造一个功能完善的 SQLite 数据库管理工具
-
如何使用PyQt6和qt_material库,打造一个功能完善的SQLite数据库管理工具,轻松管理和查询SQLite数据库。一、目标数据库连接与表管理:支持连接SQLite数据库...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
系统C盘清理:微信PC端文件清理,扩大C盘可用空间步骤
-
10款高性能NAS丨双十一必看,轻松搞定虚拟机、Docker、软路由
-
python使用fitz模块提取pdf中的图片
-
- 最近发表
-
- Springboot 整合 Websocket 轻松实现IM及时通讯
- SpringBoot扩展——应用Web Socket!
- 【Spring Boot】WebSocket 的 6 种集成方式
- SpringBoot生产级WebSocket集群实践,支持10万连接!
- Spring Boot3 中 WebSocket 实现数据实时通信全解析
- Java WebSocket 示例(java nio websocket)
- Spring Boot整合WebSocket:开启实时通信之旅
- Spring Boot3 竟能如此轻松整合 WebSocket 技术,你还不知道?
- Spring Boot集成WebSocket(springboot集成websocket)
- Springboot下的WebSocket开发(springboot websocket server)
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)