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


    什么是断言?

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

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

    接口地址:

    postman接口测试视频教程:2023全网封神,B站讲的最详细的Postman接口测试实战教学,小白都能学会_哔哩哔哩_bilibiliicon-default.png?t=N7T8https://www.bilibili.com/video/BV16L41117wB/?spm_id_from=333.999.0.0

     

    使用 GET 方法:

    Postman学习之常用断言

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

    Postman学习之常用断言

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

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

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

    我们在tests输入框填写:

    1. pm.test("Status code is 200", function () {
    2. pm.response.to.have.status(200);
    3. }); //断言响应状态码是200
    4. var jsonData = JSON.parse(responseBody);
    5. tests["Check respose id value"] = jsonData.id === 90; //断言id90
    6. tests["Check respose url value"] = jsonData.url === "https://www.v2ex.com/go/python"; //断言url

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

    Postman学习之常用断言

    查看断言结果:

    Postman学习之常用断言

    图中,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/)

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

    1. {
    2. "status": 1,
    3. "message": "success",
    4. "data": [
    5. {
    6. "id": 1,
    7. "title": "乡愁",
    8. "author": "余光中",
    9. "content": "小时候,乡愁是一枚小小的邮票,我在这头,母亲在那头。长大后,乡愁是一张窄窄的船票,我在这头,新娘在那头"
    10. },
    11. {
    12. "id": 5,
    13. "title": "乡愁",
    14. "author": "余光中",
    15. "content": "小时候,乡愁是一枚小小的邮票,我在这头,母亲在那头。长大后,乡愁是一张窄窄的船票,我在这头,新娘在那头"
    16. }
    17. ]
    18. }

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

    1. var jsonData = JSON.parse(responseBody);
    2. tests["Check respose status value"] = jsonData.status === 1;
    3. pm.test("判断data里面第一个json数据的id为1", function () {
    4. var jsonData = pm.response.json();
    5. pm.expect(jsonData.data[0].id).to.eql(1);});

    Postman学习之常用断言

     postman接口测试视频教程:2023全网封神,B站讲的最详细的Postman接口测试实战教学,小白都能学会_哔哩哔哩_bilibiliicon-default.png?t=N7T8https://www.bilibili.com/video/BV16L41117wB/?spm_id_from=333.999.0.0

    Postman常见断言方法介绍:

    设置一个环境变量

    pm.environment.set("variable_key", "variable_value");

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

    1. var array = [1, 2, 3, 4];
    2. pm.environment.set("array", JSON.stringify(array, null, 2));
    3. var obj = { a: [1, 2, 3, 4], b: { c: 'val' } };
    4. pm.environment.set("obj", JSON.stringify(obj));

    获取环境变量

    1. //variable_key代表某一变量名,下同
    2. pm.environment.get("variable_key");

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

    1. // These statements should be wrapped in a try-catch block if the data is coming from an unknown source.
    2. var array = JSON.parse(pm.environment.get("array"));
    3. 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");

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

    1. //string_you_want_to_search为需要匹配的字符串
    2. pm.test("Body matches string", function () {
    3. pm.expect(pm.response.text()).to.include("string_you_want_to_search");
    4. });

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

    1. //response_body_string 为需要匹配的响应主体
    2. pm.test("Body is correct", function () {
    3. pm.response.to.have.body("response_body_string");
    4. });

    检查JSON值

    1. pm.test("Your test name", function () {
    2. var jsonData = pm.response.json();
    3. pm.expect(jsonData.key).to.eql(100); //key为返回json一字段名,如开头接口的 stars
    4. });

    内容类型存在

    1. pm.test("Content-Type is present", function () {
    2. pm.response.to.have.header("Content-Type");
    3. });

    响应时间小于200ms

    1. pm.test("Response time is less than 200ms", function () {
    2. pm.expect(pm.response.responseTime).to.be.below(200);
    3. });

    响应状态码是200

    1. pm.test("Status code is 200", function () {
    2. pm.response.to.have.status(200);
    3. });

    代码名称包含一个字符串

    1. pm.test("Status code name has string", function () {
    2. pm.response.to.have.status("Created");
    3. });

    成功的POST请求状态码

    1. pm.test("Successful POST request", function () {
    2. pm.expect(pm.response.code).to.be.oneOf([201,202]);
    3. });

    对于JSON数据使用TinyValidator

    1. var schema = {
    2. "items": {
    3. "type": "boolean"
    4. }
    5. };
    6. var data1 = [true, false];
    7. var data2 = [true, 123];
    8. pm.test('Schema is valid', function() {
    9. pm.expect(tv4.validate(data1, schema)).to.be.true;
    10. pm.expect(tv4.validate(data2, schema)).to.be.true;
    11. });

    解码base64编码的数据

    1. var intermediate,
    2. base64Content, // 假设它有一个base64编码值
    3. rawContent = base64Content.slice('data:application/octet-stream;base64,'.length);
    4. intermediate = CryptoJS.enc.Base64.parse(base64content); // CryptoJS 是一个内置对象, 文档说明: https://www.npmjs.com/package/crypto-js
    5. pm.test('Contents are valid', function() {
    6. pm.expect(CryptoJS.enc.Utf8.stringify(intermediate)).to.be.true; //非空检查
    7. });

    发送异步请求

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

    1. pm.sendRequest("https://postman-echo.com/get", function (err, response) {
    2. console.log(response.json());
    3. });

    将XML正文转换为JSON对象

    var jsonObject = xml2Json(responseBody);

     postman接口测试视频教程:2023全网封神,B站讲的最详细的Postman接口测试实战教学,小白都能学会_哔哩哔哩_bilibiliicon-default.png?t=N7T8https://www.bilibili.com/video/BV16L41117wB/?spm_id_from=333.999.0.0

  • 相关阅读:
    lv3 嵌入式开发-4 linux shell命令(文件搜索、文件处理、压缩)
    C++零碎记录(十三)
    第7章——链接
    Java配置35-搭建Gitlab服务器
    2022/7/30
    ffmpeg云服务器推流
    基于springboot实现民宿管理平台项目【项目源码+论文说明】计算机毕业设计
    CryptoCTF easy
    UNIAPP实战项目笔记47 显示默认收货地址和修改收货地址页面的布局
    人工智能学习
  • 原文地址:https://blog.csdn.net/MXB_1220/article/details/133612776