接口自动化测试(二)—— Postman实现接口测试

news2025/1/13 11:59:53

其他 接口自动化测试 知识参考:接口自动化测试

目录

一、Postman介绍和安装

1、简介

2、安装

3、安装Postman插件newman 

二、Postman基本用法

1、案例一

2、案例二

三、Postman高级用法

1、管理测试用例Collections

1.1、创建 collections

1.2、创建 用例集、子目录和 请求

2、用例集导出、导入

2.1、导出

2.2、导入

3、Postman 断言简介

4、Postman 常用断言

4.1、断言响应状态码

4.2、断言响应体是否包含某个字符串

4.3、断言响应体是否等于某个字符串(对象)

4.4、断言JSON数据

4.5、断言响应头

5、Postman断言工作原理

6、全局变量和环境变量

6.1、全局变量 

6.2、环境变量

7、Postman 请求前置脚本

8、Postman 请求前置脚本的工作原理

9、Postman 关联 

批量执行测试用例

四、Postman测试报告

使用newman生成测试报告


其他 接口自动化测试 知识参考:接口自动化测试

一、Postman介绍和安装

1、简介

  • Postman是一款非常流行的接口调试工具,它使用简单,而且功能也很强大。不仅测试人员会使用,开发人员也会经常使用。

  • 特征:

    1. 简单易用的图形用户界面

    2. 可以保存接口请求的历史记录

    3. 使用测试集Collections可以更有效的管理组织接口

    4. 可以在团队之间同步接口数据

最新版本下载官方下载页面 下载链接:Win64 Win32 Mac Linux
-注意 👇👇👇👇👇 看下面 👇👇👇👇👇 注意
历史版本下载请把下面链接的"版本号"替换为指定的版本号,例如:9.12.2
Windows64位https://dl.pstmn.io/download/version/版本号/win64
Windows32位https://dl.pstmn.io/download/version/版本号/win32
Mac Intel Chiphttps://dl.pstmn.io/download/version/版本号/osx_64
Mac Apple Chiphttps://dl.pstmn.io/download/version/版本号/osx_arm64
Linuxhttps://dl.pstmn.io/download/version/版本号/linux

官网         汉化步骤与汉化文件下载地址       

2、安装

双击Postman安装包,全自动安装,不需要任何人为干预。 安装完成后,会默认打开英文注册页面。或者手动打开注册页面。 自行翻译英文页面提示,根据提示完成注册或登录,完全免费

3、安装Postman插件newman 

前提:安装node.js

1. windows使用win + R,输入cmd打开终端,输入命令 npm -v,如能显示版本号(版本略有差异无所谓)。 可跳过 “1 安装node.js” 这步,直接看 “2 安装 newman”。

        如显示, npm 命令无法识别,则需下载node.js(下载地址),下载完成双击安装即可,安装完成后,在终端输入npm -v验证是否安装成功。

2. 安装newman (前提:确保 npm -v 验证通过)

        在线安装命令:

npm install -g newman

        尽量避开网络访问高峰期(早7:30~9:30 午11:30~14:30 晚18:30~22:30)安装,保证安装时网络稳定。 如果安装失败,反复尝试。大约尝试 10 几次 或 几十次!

        国内推荐切换npm镜像源:

         

nrm -V 查看版本,以及是否安装成功
# 1.查看当前使用的镜像地址
nrm ls 查看所有源地址, *表示当前使用的镜像地址
# 2.切换镜像源  淘宝
nrm use taobao

3. 安装newman-reporter-html

npm install -g newman-reporter-html

二、Postman基本用法

1、案例一

使用 postman 发送 http请求,访问 tpshop 商城的 “搜索” 接口

访问 tpshop 商城的 “搜索” 接口所需要的信息:

—— 结合 F12 浏览器开发者工具分析:

  • 请求方法:GET

  • URL:http://tpshop-test.itheima.net/Home/Goods/search.html?q=%E6%89%8B%E6%9C%BA

  • 请求头:无

  • 请求体:无

  • 返回数据:html网页

2、案例二

使用 Postman 向 topshop 商城 登录接口 发送一个密码错误的 登录请求

  • 请求方法:post

  • URL:http://tpshop-test.itheima.net/index.php?m=Home&c=User&a=do_login&t=0.6693319462870182

  • 请求头:Content-Type:application/x-www-form-urlencoded

  • 请求体:

    • username: 13812345678

    • password: 12345699999

    • verify_code : 8888

  • 返回数据:

    {"status":-2,"msg":"密码错误!"} ---- 实际返回结果 “验证码错误” 与业务有关,后续说明

 

三、Postman高级用法

1、管理测试用例Collections

1.1、创建 collections

1.2、创建 用例集、子目录和 请求

2、用例集导出、导入

2.1、导出

  

2.2、导入

 

3、Postman 断言简介

  • postman 断言借助 JavaScript - js 语言编写代码,自动判断预期结果与实际结果是否一致。

  • 断言 代码写在 Tests 的标签中。

4、Postman 常用断言

4.1、断言响应状态码

Status code: Code is 200

  1. 在 Tests 标签中,选中 Status Code:code is 200, 生成对应代码

  2. 适当调整 test() 方法参数1,和 匿名函数中的 预期结果。

  3. 点击 send 按钮,发送请求,执行断言代码。

  4. 查看断言结果。

    // 断言响应状态码 是否为 200
    pm.test("Status code is 200", function () {
        pm.response.to.have.status(200);
    });
    
    pm:代表 postman 的一个实例
    test():是 pm实例的一个方法。有两个参数
    	参数1:在断言成功后,给出的文字提示。可以修改。"Status code is 200"
    	参数2:匿名函数。
    pm.response.to.have.status(200); 
    // 意思:postman 的响应结果中应该包含状态码 200
    		200 ——> 预期结果!

4.2、断言响应体是否包含某个字符串

Response body: Contains string

// 断言响应体包含指定字符串
pm.test("Body matches string", function () {
    pm.expect(pm.response.text()).to.include("string_you_want_to_search");
});

pm:postman的一个实例
test(): postman实例的方法,有两个参数
	参1:断言后显示的文字提示信息,可改。
    参2:匿名函数
pm.expect(pm.response.text()).to.include("string_you_want_to_search"); 
// 意思:pm 期望 响应文本 中,包含 xxxx 字符串。
	"string_you_want_to_search" ——> 预期结果。 可以修改

4.3、断言响应体是否等于某个字符串(对象)

Response body: Is equal to a string

// 断言 响应体 等于某个字符串(对象)
pm.test("Body is correct", function () {
    pm.response.to.have.body("response_body_string");
});

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

// 意思是,pm 的 响应中应该有 响应体 xxx
"response_body_string" ——> 预期结果。 可以修改

4.4、断言JSON数据

Response body: JSON value check

// 断言json的响应结果
pm.test("Your test name", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.value).to.eql(100);
});

var jsonData = pm.response.json();
// var jsonData: 用js语法定义一个变量。jsonData 就是变量名
// pm.response.json();  代表响应的json结果

/* 举例:response.json();
{
    "success": true,
    "code": 10000,
    "message": "操作成功!",
    "data": "95c78d75-721c-40fb-b2d5-742fea42cbd5"
}
*/
pm.expect(jsonData.value).to.eql(100);
// 意思:pm 预期 json结果 key对应的值 等于 xxx
// to.eql(100); 中的 100 代表预期结果。可以修改的。

/* 举例:
		jsonData.value 的  value:
        取 :success、code、message、data
*/

示例:

// 断言json的响应结果-success的值为true
pm.test("断言响应结果success的值为true", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.success).to.eql(true);
});

pm.test("断言响应结果中code的值为10000", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.code).to.eql(10000);
});

pm.test("断言响应结果中message的值为 操作成功", function () {
    var jsonData = pm.response.json();
    pm.expect(jsonData.message).to.eql("操作成功!");
});

4.5、断言响应头

Response headers: Content-Type header check

// 断言响应头
pm.test("Content-Type is present", function () {
    pm.response.to.have.header("Content-Type");
});

pm.response.to.have.header("Content-Type");
// pm 的响应 头中包含 Content-Type

// 示例:可以在 header 中,添加 响应头中的 key 对应的 value 判定。用 ,隔分。
// 断言响应头
pm.test("Content-Type is present", function () {
    pm.response.to.have.header("Content-Type", "application/json;charset=UTF-8");
});

5、Postman断言工作原理

6、全局变量和环境变量

6.1、全局变量 

  • 概念:在 Postman 全局生效的变量,全局唯一。

  • 设置:

    • 代码设置pm.globals.set(“全局变量名”,全局变量的值)

      // 示例:
      pm.globals.set("glb_age", 100)
  • 获取:

    • 代码获取: var 接收值的变量 = pm.globals.get(“全局变量名”)

      // 示例:
      var ret = pm.globals.get("glb_age")  // ret 的值为 100
    • 请求参数获取(postman界面获取): {{全局变量名}}

      // 示例:
      {{glb_age}}

6.2、环境变量

  • 概念:在 特定环境(生产环境、开发环境、测试环境)下,生效的变量,在本环境内唯一。

  • 设置:

    • 代码设置:pm.environment.set("环境变量名", 环境变量值)

      // 示例
      pm.environment.set("env_age", 99)
  • 获取:

    • 代码获取:var 接收值的变量 = pm.environment.get("环境变量名")

      // 示例
      var ret = pm.environment.get("env_age")  // ret 的值为 99
    • 请求参数获取(postman界面获取):{{环境变量名}}

      // 示例
      {{env_age}}

7、Postman 请求前置脚本

  • 在 send 按钮点击后,请求前置脚本代码,第一时间被执行。在 postman 内部实际 http请求之前。

假设,这样一种场景:

调某接口时,要输入 “时间戳”,如果输入的 “时间戳” 的绝对值,超过标准时间10分钟。 则不允许调用。

时间戳

  • 时间戳:对应绝对时间,从 1970年1月1日00:00:00 到现在 所经历的秒数。

一天:86400秒

51年 6月(180) 9天 --- 1,624,665,600 秒

案例

调用百度首页接口,传时间戳给服务器

实现步骤:

  1. Pre-request Script 标签页中,添加代码。拿到时间戳,写入全局变量

    // 拿到时间戳
    var timestamp = new Date().getTime()
    ​
    // 将时间戳设置到 全局变量
    pm.globals.set("glb_timestamp", timestamp)
  2. 点击 Send 按钮,发送请求。请求发送前执行 上述代码。写入全局变量

  3. 查看写入的变量

  4. 在 请求参数(界面)中,使用全局变量。{{全局变量名}}

  5. 在 postman的 控制台,查看 发送的 http请求

8、Postman 请求前置脚本的工作原理

9、Postman 关联 

介绍:应用于 多个 http请求之间,有数据关联、或依赖关系时。

实现步骤

A接口 依赖 B接口 的数据

  1. 向B接口发送http请求,获取数据

  2. 将数据 设置 至 全局变量(环境变量)中

  3. A 接口 获取 全局变量(环境变量)中 数据值,进行使用。

案例

请求 获取天气接口, 提取响应结果中的 城市, 将城市名,给百度搜索接口使用。

实现步骤:

  1. 创建 用例集,分别创建 查询天气 请求 和 百度搜索的请求

  2. 在查询天气请求 Tests 中,编写代码 获取 城市名,写入全局变量

    // 获取 全部响应结果
    var jsonData = pm.response.json()
    // 从响应结果中 获取 城市名
    var city = jsonData.weatherinfo.city
    // 将城市名写入到全局变量
    pm.globals.set("glb_city", city)
  3. 点击 Send 按钮,发送 请求,查看设置的全局变量。

  4. 修改 百度搜索请求,使用全局变量,按 城市名进行搜索。

    http://www.baidu.com/s?wd={{glb_city}}

批量执行测试用例

四、Postman测试报告

参考:接口自动化测试(三)—— Postman读取外部数据文件(参数化)

安装newman ,请参考上方安装插件。

使用newman生成测试报告

步骤:

  1. 批量执行测试用例集。(确认无误)

  2. 导出 Export 用例集。(得到 xxxx.json文件)

  3. 终端 中 执行命令,生成测试报告

# 现在 终端中,测试一下。
newman run xxxx.json

# 完整的命令
newman run xxxx.json -e 环境变量文件 -d 外部数据文件 -r html --reporter-html-export 测试报告名.html

# 示例:
newman run 批量执行测试用例.postman_collection.json -r html --reporter-html-export 我的第一个测试报告.html

# 如果添加 -r html 就报错!说明: newman-reporter-html 安装失败!

 其他 接口自动化测试 知识参考:接口自动化测试

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/30.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

libusb系列-002-Windows下libusb源码编译

libusb系列-002-Windows下libusb源码编译 文章目录libusb系列-002-Windows下libusb源码编译摘要Windows下编译libusb库下载源码进入msvc目录选择对应的项目工程编译查看编译好的库文件关键字: vs、 编译、 Qt、 libusb、 windows内容背景: 最近项目终于切…

从 0 到 1 落地前端工程化

你将获得 初识:总结前端工程化技能图谱 了解:梳理前端工程化落地流程 掌握:搭建前端工程化基建项目 提高:实战前端工程化解决方案 作者介绍 JowayYoung,资深前端工程师,目前就职于网易互动娱乐事业群&…

建立私人知识网站 cpolar轻松做到1 (部署DokuWiki)

维基百科(wiki)相信大家都有所耳闻,作为全球最有名的百科知识搜索网站,很多不常见的知识点都能在这上面搜索到,而维基百科能够成功的原因,就是可以编辑的和修订的功能,让维基百科能够收到各领域…

vue学习笔记——简单入门总结(一)

Vue学习笔记 文章目录Vue学习笔记1. 学习vue的准备1.1. vue简介:1.2. vue特点:1.2.1. 组件化:1.2.1. 声明式:1.2. vue的引入1.2.1. 直接引入:1.2.2. 脚手架构建vue项目:1.2.3:vue开发插件安装:2. vue的简单…

apache服务web页面执行shell脚本

首先安装apache服务 yum -y install httpd 如下介绍两种执行的方式 方式一、url直接传参的方式 #cat /var/www/cgi-bin/shell #!/bin/sh printf "Content-Type: text/plain\n\n" your_commands_here传参的动作 http://172.16.61.119:8098/cgi-bin/shell?pwd在…

STM32使用寄存器开发底层驱动学习(USART+DMA)

目录学习资料下载任务USART的DMA功能发送数据DMA非中断模式接收USART数据。DMA中断模式接收USART数据总结学习资料下载 在本文学习中会用到如下的文档资料,没有的朋友先下载。 工程模板 Cortex M3权威指南(中文) :本文简称为《…

1024程序节|你知道老师上课随机点名是怎么实现的吗

个人主页:天寒雨落的博客_CSDN博客-C,CSDN竞赛,python领域博主 目录 前言 随机点名 搭建主体框架 简述 执行代码 添加功能 块级元素随机输出姓名 Math.random() Math.round() 按钮控制开始/结束 onclick() clearInterval() 简述 完整代码 执行结果 片…

I/O复用--浅谈epoll

我们聊了聊select和poll知道: 它们都是采取轮询的方式查找是否有就绪描述符。都有数据结构从用户态拷贝到内核态,内核态拷贝到用户态这个过程。 为了针对许多大量连接,高并发的的场景下大量的资源消耗,效率低的问题,这…

网络安全实战:记一次比较完整的靶机渗透

0x01信息搜集 nmap -sC -sV -p- -A 10.10.10.123 -T4 -oA nmap_friendzone访问80端口的http服务只发现了一个域名。 0x02 DNS区域传输 因为我们前面扫描的时候发现了53端口是开着一个dns服务的,所以尝试使用friendzoneportal.red进行axfr,它的具体含…

《软件测试》实验2:嵌入式软件测试实验报告

文章目录实验目的温度控制器需求文档及测试要求环境搭建实验内容温度采集处理功能测试加热棒输出电压测试散热风扇温度传感器输入接口(Senser_JK)控制加热棒输出接口(Heater_JK)控制散热风扇输出接口(Fan_JK&#xff0…

目标检测 YOLOv5 - 模型推理预处理 letterbox

目标检测 YOLOv5 - 模型推理预处理 letterbox flyfish 版本:YOLOv5 6.2 假如图片大小是1080 * 1920 (height * width ) width 1920 height 1080 当模型输入是 640 * 640时 shapes (1080, 1920), (0.33, 0.33), (0.0, 140.0) 640/ 1920…

c++11 右值引用和移动语义

文章目录1. 左值引用和右值引用2. 左值引用与右值引用比较3. 右值引用使用场景和意义3.1左值引用的使用场景3.2左值引用的短板:3.3 移动构造3.4 移动赋值3.5 STL中的容器3.6 右值引用引用左值及其一些更深入的使用场景分析3.7 STL容器插入接口函数也增加了右值引用版…

Springboot 使用装饰器模式,快看,它装起来了

前言 小飞棍来咯! 本篇文章跟小飞棍一毛钱关系没有。 本篇内容: 就是配合实战案例介绍我们平时 在springboot项目里面 怎么去用 装饰器模式、多层装饰怎么玩。 正文 首先先说下装饰器模式是什么 官方: 装饰器模式(Decorator Pa…

Python3,5行代码,制作Gif动图,太简单了。

gif动图制作1、引言2、代码实战2.1 安装2.2 代码3、总结1、引言 小屌丝:鱼哥, 你能不能帮我找一个动图, 小鱼:啥动图,你自己百度不就行了。 小屌丝:我这不是没找到吗, 不然我就自己来找了。 小…

Oracle数据库:net configureation assistant工具配置监听listener,配置本地网络访问服务器上的数据库

Oracle数据库:net configureation assistant工具配置监听listener,配置本地网络访问服务器上的数据库 2022找工作是学历、能力和运气的超强结合体,遇到寒冬,大厂不招人,可能很多算法学生都得去找开发,测开…

图像类找工作面试题(二)——常见问题大总结

文章目录一、深度学习问题1、目标检测系列(1)介绍目标检测网络YOLO以及SSD系列原理。(2)YOLO对小目标检测效果不好的原因,怎么改善?(3)怎么防止过拟合(4)Drop…

Ubuntu18.04LTS环境下创建OpenCV4.x-Android库

1 背景 1.1 java.lang.UnsatisfiedLinkError: dlopen failed: library “libc_shared.so” not found libc_shared.so 之前默认集成在 opencv_java3.so,但是在OpenCV4.x以后,该动态库默认不集成在opencv_java4.so。 1.2 E/OpenCV/StaticHelper: OpenC…

NLP学习之:Bert 模型复现(1)任务分析 + 训练数据集构造

​ 文章目录代码资源原理学习任务代码讲解代码重写说明代码资源 Bert-pytorch 原理 学习任务 Bert 本质上是 Transformer 的 Encoder 端,Bert 在预训练时最基本的任务就是: 判断输入的两个句子是否真的相邻预测被 [MASK] 掉的单词 通过这两种任务的约…

面了个腾讯拿28k跳槽出来的,真正见识到了跳槽天花板

最近内卷严重,各种跳槽裁员,相信很多小伙伴也在准备金九银十的面试计划。 作为一个入职5年的老人家,目前工资比较乐观,但是我还是会选择跳槽,因为感觉在一个舒适圈待久了,人过得太过安逸,晋升涨…

ToDesk使用

现在的终端产品种类非常的多,常见的包括tablet, 手机,笔记本 ,ipod...等等,这些终端带屏产品连同台式机,智能电视等固定设备占据了我们的工作和生活中的大部分时间,不知道你发现没有,使这些不同种类的产品之…