postman使用--断言
前戏
在我们测接口的时候,没有断言的接口都是耍流氓,因为做自动化的时候,不加断言我们不知道这个接口是执行成功了还是执行失败了,所以断言是做接口自动化必须的
断言
断言就是我们预期值和接口返回值是否一样,就和我们写功能测试用例时的预期结果一个意思
pre-request Script(预置脚本)可以用来修改一些默认参数,在请求发送之前执行
test Scripr(测试脚本):当接受到响应之后,在执行脚本
还是我们上节讲的A接口,我们来断言返回值中是不是有zouzou666,如果有,则认为接口执行成功,没有则失败
在test里设置断言
pm.test("包含字符串",function(){
pm.expect(pm.response.text()).to.include("zouzou666");
});
如果执行成功则在Test Results里显示PASS,那我们把断言改为失败试试
我们发现,断言失败会显示成FALL的,当然我们可以在Test下面添加多个断言
postman脚本执行顺序
也就是先执行最上层的文件夹里的pre-request Script,在执行它下面文件夹里的pre-request Script,在执行请求里的pre-request Script。在发送请求,在执行最上层的文件夹里的Tests,在执行它下面文件夹里的Tests,最后执行请求里的Tests
常用的断言
判断返回结果是不是在1s之内
pm.test("返回结果在1s之内",function(){
pm.expect(pm.response.responseTime).to.be.below(1000);
});
判断返回结果是不是在300ms左右
pm.test("判断返回结果在300ms左右",function(){
pm.expect(pm.response.responseTime).to.be.closeTo(300,200);
});在300ms的上下200ms,也就是100--500ms之间
断言返回的状态码是不是200
tests["返回状态码正确"]=responseCode.code===200; pm.test("返回正确",function(){ // pm.response.to.have.status(200); pm.response.to.be.ok; })
pm.test("包含字符串",function(){ pm.expect(pm.response.text()).to.include("@#sd1135"); }); pm.test("包含字符串",function(){ pm.expect(pm.response.text()).to.include("38dd572dd9c14c73b7637893c0592aa7"); }); pm.test("包含字符串",function(){ pm.expect(pm.response.text()).to.include("10"); });
设置环境变量
pm.environment.set("variable_key", "variable_value");
将嵌套对象设置为环境变量
var array = [1, 2, 3, 4]; pm.environment.set("array", JSON.stringify(array, null, 2)); var obj = { a: [1, 2, 3, 4], b: { c: 'val' } }; pm.environment.set("obj", JSON.stringify(obj));
获取环境变量
pm.environment.get("variable_key");
获取环境变量(其值是字符串化对象)
var array = JSON.parse(pm.environment.get("array")); var obj = JSON.parse(pm.environment.get("obj"));
清除环境变量
pm.environment.unset("variable_key");
设置全局变量
pm.globals.get("variable_key");
清除全局变量
pm.globals.unset("variable_key");
检查响应主体是否包含字符串
pm.test("Body matches string", function () { pm.expect(pm.response.text()).to.include("string_you_want_to_search"); });
检查响应主体是否等于字符串
pm.test("Body is correct", function () { pm.response.to.have.body("response_body_string"); });
检查JSON值
pm.test("Your test name", function () { var jsonData = pm.response.json(); pm.expect(jsonData.value).to.eql(100); });
内容类型存在
pm.test("Content-Type is present", function () { pm.response.to.have.header("Content-Type"); });
响应时间小于200毫秒
pm.test("Response time is less than 200ms", function () { pm.expect(pm.response.responseTime).to.be.below(200); });
状态代码是200
pm.test("Status code is 200", function () { pm.response.to.have.status(200); });
代码名称包含一个字符串
pm.test("Status code name has string", function () { pm.response.to.have.status("Created"); });
成功的POST请求状态代码
pm.test("Successful POST request", function () { pm.expect(pm.response.code).to.be.oneOf([201,202]); });
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)