Postman接口测试学习之常用断言

什么是断言?

断言------就是结果中的特定属性或值与预期做对比,如果一致,则用例通过,如果不一致,断言失败,用例失败。断言,是一个完整测试用例所不可或缺的一部分,没有断言的测试用例仅仅是测试步骤。​

在介绍Postman断言之前,我们先测试接口:

接口地址:

使用 GET 方法:

那么这个接口我们如何用Postman来进行断言呢?也很简单,用到Postmantests这个模块。

要执行断言脚本以验证请求返回的数据,使用pm.test函数定义断言,他提供一个名称和函数,该函数返回一个布尔值(true或false)来指示测试是通过还是失败。并结合使用pm.response对象和pm.expect来测试响应详细信息。

那么上面的接口我们如何断言呢?很简单,从响应内容做断言。

比如我们可以断言 id=90,url = "https://www.v2ex.com/go/python",响应状态码等于200

我们在tests输入框填写:

python 复制代码
pm.test("Status code is 200", function () {

pm.response.to.have.status(200);

}); //断言响应状态码是200


var jsonData = JSON.parse(responseBody);

tests["Check respose id value"] = jsonData.id === 90; //断言id是90

tests["Check respose url value"] = jsonData.url === "https://www.v2ex.com/go/python"; //断言url

操作步骤:1、填写断言 2、点击send

查看断言结果:

图中,Test Results(3/3)表示3条断言都执行成功

错误:运行报错 There was an error in evaluating the Pre-request Script: pm is not defined

解决办法:出现此问题是在使用Chrome的应用程序时,安装完整的独立版本后,pm对象可以正常工作。(安装包官网下载地址:https://www.postman.com/downloads/)

当然上面断言是比较简单的断言,如果返回的数据如下所示,我们应该如何断言呢?

python 复制代码
{

"status": 1,

"message": "success",

"data": [

{

"id": 1,

"title": "乡愁",

"author": "余光中",

"content": "小时候,乡愁是一枚小小的邮票,我在这头,母亲在那头。长大后,乡愁是一张窄窄的船票,我在这头,新娘在那头"

},

{

"id": 5,

"title": "乡愁",

"author": "余光中",

"content": "小时候,乡愁是一枚小小的邮票,我在这头,母亲在那头。长大后,乡愁是一张窄窄的船票,我在这头,新娘在那头"

}

]

}

跟上面断言不同的是,data里面可能有多个json格式的数据,如果我们想断言data里面第一个json应该如何断言呢?其实也非常简单,我们在tests输入框填写:

python 复制代码
var jsonData = JSON.parse(responseBody);

tests["Check respose status value"] = jsonData.status === 1;

pm.test("判断data里面第一个json数据的id为1", function () {

var jsonData = pm.response.json();

pm.expect(jsonData.data[0].id).to.eql(1);});
Postman常见断言方法介绍:

设置一个环境变量

复制代码
pm.environment.set("variable_key", "variable_value");

将嵌套对象设置为环境变量

python 复制代码
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));

获取环境变量

  1. //variable_key代表某一变量名,下同

  2. pm.environment.get("variable_key");

获取一个环境变量(其值是一个字符串化的对象)

python 复制代码
// These statements should be wrapped in a try-catch block if the data is coming from an unknown source.


var array = JSON.parse(pm.environment.get("array"));

var obj = JSON.parse(pm.environment.get("obj"));

清除一个环境变量

复制代码
pm.environment.unset("variable_key");

设置一个全局变量

  1. //variable_value为设置变量的值

  2. pm.globals.set("variable_key", "variable_value");

获取一个全局变量

复制代码
pm.globals.get("variable_key");

清除全局变量

复制代码
pm.globals.unset("variable_key");

获取一个变量

该函数在全局变量和活动环境中搜索变量。

复制代码
pm.variables.get("variable_key");

检查响应主体是否包含字符串

python 复制代码
//string_you_want_to_search为需要匹配的字符串

pm.test("Body matches string", function () {

pm.expect(pm.response.text()).to.include("string_you_want_to_search");

});

检查响应主体是否等于一个字符串

python 复制代码
//response_body_string 为需要匹配的响应主体

pm.test("Body is correct", function () {

pm.response.to.have.body("response_body_string");

});

检查JSON值

python 复制代码
pm.test("Your test name", function () {

var jsonData = pm.response.json();

pm.expect(jsonData.key).to.eql(100); //key为返回json一字段名,如开头接口的 stars

});

内容类型存在

python 复制代码
pm.test("Content-Type is present", function () {

pm.response.to.have.header("Content-Type");

});

响应时间小于200ms

python 复制代码
pm.test("Response time is less than 200ms", function () {

pm.expect(pm.response.responseTime).to.be.below(200);

});

响应状态码是200

python 复制代码
pm.test("Status code is 200", function () {

pm.response.to.have.status(200);

});

代码名称包含一个字符串

python 复制代码
pm.test("Status code name has string", function () {

pm.response.to.have.status("Created");

});

成功的POST请求状态码

python 复制代码
pm.test("Successful POST request", function () {

pm.expect(pm.response.code).to.be.oneOf([201,202]);

});

对于JSON数据使用TinyValidator

python 复制代码
var schema = {

"items": {

"type": "boolean"

}

};

var data1 = [true, false];

var data2 = [true, 123];


pm.test('Schema is valid', function() {

pm.expect(tv4.validate(data1, schema)).to.be.true;

pm.expect(tv4.validate(data2, schema)).to.be.true;

});

解码base64编码的数据

python 复制代码
var intermediate,

base64Content, // 假设它有一个base64编码值

rawContent = base64Content.slice('data:application/octet-stream;base64,'.length);


intermediate = CryptoJS.enc.Base64.parse(base64content); // CryptoJS 是一个内置对象, 文档说明: https://www.npmjs.com/package/crypto-js

pm.test('Contents are valid', function() {

pm.expect(CryptoJS.enc.Utf8.stringify(intermediate)).to.be.true; //非空检查

});

发送异步请求

该功能既可以作为预先请求,也可以作为测试脚本使用。

python 复制代码
pm.sendRequest("https://postman-echo.com/get", function (err, response) {

console.log(response.json());

});

将XML正文转换为JSON对象

复制代码
var jsonObject = xml2Json(responseBody);

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关推荐
Hello_Embed3 小时前
STM32HAL 快速入门(二十):UART 中断改进 —— 环形缓冲区解决数据丢失
笔记·stm32·单片机·学习·嵌入式软件
咸甜适中4 小时前
rust语言 (1.88) 学习笔记:客户端和服务器端同在一个项目中
笔记·学习·rust
Magnetic_h5 小时前
【iOS】设计模式复习
笔记·学习·ios·设计模式·objective-c·cocoa
研梦非凡5 小时前
ICCV 2025|从粗到细:用于高效3D高斯溅射的可学习离散小波变换
人工智能·深度学习·学习·3d
limengshi1383926 小时前
机器学习面试:请介绍几种常用的学习率衰减方式
人工智能·学习·机器学习
知识分享小能手7 小时前
React学习教程,从入门到精通,React 组件核心语法知识点详解(类组件体系)(19)
前端·javascript·vue.js·学习·react.js·react·anti-design-vue
周周记笔记8 小时前
学习笔记:第一个Python程序
笔记·学习
java搬砖工-苤-初心不变8 小时前
基于 lua_shared_dict 的本地内存限流实现
开发语言·junit·lua
优雅鹅8 小时前
ARM、AArch64、amd64、x86_64、x86有什么区别?
arm开发·学习
..过云雨8 小时前
05.【Linux系统编程】进程(冯诺依曼体系结构、进程概念、进程状态(注意僵尸和孤儿)、进程优先级、进程切换和调度)
linux·笔记·学习