接口测试 - postman

news2024/12/24 0:16:59

文章目录

  • 一、接口
    • 1.接口的类型
    • 2. 接口测试
    • 3. 接口测试流程
    • 4. 接口测试用例
      • 1. 测试用例
      • 单接口测试用例-登录案例
  • 二、HTTP协议
    • 1. HTTP请求
    • 2. HTTP响应
  • 三、postman
    • 1. 界面导航说明
      • 导入 导出用例集
    • Get请求和Post请求的区别:
    • 2.postman环境变量和全局变量
    • 3. postman 请求前置脚本
    • 4. postman断言
      • 常规六种断言
        • 断言响应状态码
      • 自定义动态参数(全局变量)断言的方式:
      • 全局断言
    • 5. 接口关联
      • 使用json提取器实现接口关联
      • 使用正则表达式提取器实现接口关联
      • 案例
    • 6. 测试必须带请求头的接口
    • 7. Postman接口Mock Servier服务器
    • 8. 接口加密
    • 9. 批量执行用例集
    • 10. 接口测试报告
      • 使用newman生成测试报告
      • 生成 环境 下的测试报告
    • 11. poatman参数化
      • 1. 导入外部数据文件(CSV / JSON)
      • 2. 读取数据文件数据
      • 案例:按手机号找运营商
  • 总结


一、接口

接口概念:系统与系统之间,组件与组件之间,数据传递交互的通道

1、什么是接口?
电脑:USB,投影机(数据传输)
软件:统称API,application, program,interface微信提现和充值,支付宝支付,银联支付接口。(鉴权码: token,key,appkey)
接口包括:内部接口和外部接口
内部接口:开发人员自己开发的对自身系统提供的接口。
外部接口:开发系统调用外部的,微信,支付宝,其他的接口。
总结:接口就是软件提供给外部的一种服务。用于做数据传输。
2.软件为什么需要接口?
因为接口能够让内部的数据被外部进行修改。
3.我们为什么要做接口测试?
(1)现在很多系统都是前后端分离,开发的进度不一样,需要把一开始开发出来的接口进行测试。
(2)基于安全考虑,前端有验证很容易绕过,直接请求接口,特别:身份证信息,银行卡金钱交易。
(3)测试推崇的是测试左移,测试尽早的介入。

1.接口的类型

1.按协议划分: http、 tcp、 IP
2.按语言划分:C++、java、php…
3.按范围划分:
a.系统之间: 多个内部系统之间、内部系统与外部系统之间
b.程序之间:方法与方法之间,函数与函数之间,模块与模块之间

# 接口
def eat(food):
    print(f'小鸟吃{food}')

# 使用接口,传递数据
def bird():
    print(eat('虫子'))

bird()

2. 接口测试

接口测试就是,对系统或组件之间的接口进行测试。校验传递的数据正确性和逻辑依赖关系的正确性!
接口测试,主要针对的测试目标—>服务器

  • 怎么测?
    模拟客户端,向服务器发送请求。
  • 用什么测?
    。工具: fiddler、 postman、 jemter
    。代码: python + UnitTest框架+ Requests框架
  • 测什么?
    测试服务器针对客户端请求,回发的响应数据是否与预期结果一致!

3. 接口测试流程

1.分析需求,产生需求文档(产品)
2.开发产生接口文档,解析接口文档
3.根据接口文档编写接口测试用例(送审)
4.执行测试用例

  • 工具:postman、jmeter、fiddler
  • 代码:python + requests + unittest

5.提交、跟踪缺陷
6.生成测试报告
7.(可选)接口自动化集成

接口文档:
1.能够让前端开发与后台开发人员更好的配合,提高工作效率。(有一 个统一参考的文件)
2.项目迭代或者项目人员更迭时,方便后期人员查看和维护
3.方便测试人员进行接口测试

4. 接口测试用例

1.防止测试点漏测。条理清晰
2.方便分配工具,评估工作量和时间

接口测试有:功能测试性能测试安全测试

1.手工测试,测写入到输入框中的数据是否正确。接口测试测参数对应的参数值是否正确。
2.接口测试,不单单针对参数值进行,还可以针对参数本身进行测试。

  • 正向参数:
    必选参数:所有的必选(必填)都包含。
    组合参数:所有的必选 + 任意一个或多个可选参数。
    全部参数:所有的必选 + 所有的可选参数
  • 反向参数:
    多参:多出一个或多个必选参数(可以任意指定)
    少参:缺少一个或多个必选参数。
    无参:没有必选参数。
    错误参数:参数名输入错误。

1. 测试用例

手工测试八大要素:编号、用例名称、模块、优先级、预置条件、测试数据、操作步骤、预期结果

接口测试十大要素:编号、用例名称、模块、优先级、预置条件、请求方法、URL、请求头、请求体、预期结果

单接口测试用例-登录案例

功能测试有:
1.单接口测试
2.业务场景功能测试:(按用户的实际使用场景,设计接口业务场景,建议用最少测业务场景,覆盖最多的接口)
例如:登录 - 添加用户 - 查询用户 - 修改用户- 再次查询 - 删除用户 - 查询用户

两个参数:手机号和密码
登录模块测试点:

  • 数值
    正向:登陆成功
    反向:
    1.用户名为空
    2.用户名包含特殊字符/字母
    3.用户名超过11位(12位)
    4.用户名不超过11位(10位)
    5.用户名未注册
    6.密码为空
    7.密码包含特殊字符/字母
    8.密码为1位
    9.密码错误

  • 参数(接口测试特有)
    正向:
    1.必选参数:正确用户名 + 正确密码
    2.可选参数:忽略
    3.全部参数:正确用户名 + 正确密码
    反向:
    1.多参:多abc:“123”
    2.少参:(少mobile) 没有用户名,正确密码
    3.无参:没有任何参数
    4.错误参数:(手机号参数名错误) abc:13800000002,password:123456

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、HTTP协议

什么是http协议?
http是超文本传输协议,主要用于浏览器和服务器之间交互数据,交互有两个部分:
HTTP请求: get,post,put,delete
HTTP响应: 1XX信息, 2XX成功, 3XX重定向(跳转不传值), 4XX客户端错误 , 5XX服务器错误。

1. HTTP请求

HTTP请求由三部分组成:请求行、请求头、请求体

完整格式:
请求行: http请求第一 行。 请求方法(空格) URL (空格)协议版本
请求头:语法格式: k: v
1.User-Agent: 描述请求发送端的浏览器类型。
2.Content-Type: 描述请求体的数据类型!

  • application/json: JSON数据格式
  • application/x-www-form-urlencoded: form表单数据

空行:代表http请求头结束。
请求体:请求发送时携带的数据。数据类型Content-Type的值!

2. HTTP响应

HTTP响应由三部分组成:响应行、响应头、响应体

完整格式:
响应行(状态行) :协议版本(空格)状态码(空格)状态描述

  • 状态码:
    1xx:代表指示信息。表请求已经被接收,等待继续处理。
    2xx:代表请求成功被处理、接收。常见: 200、 201
    3xx:重定向,待访问的资源,需求重新指定路径访问。
    4xx.代表客户端错误。常见: 404(请求路径不存在)、403(无权限访问)
    5xx:服务端错误。

响应头:Content-Type:描述响应体中数据类型。
空行:代表响应头结束
响应体:绝大多数不为空。回发给客户端的消息内容。常见的有htm|网页、xml、json (请求成功: 回发数据,失败:回发错误信息),数据类型受Content-Type值影响。

三、postman

问题:
1.多种环境: 开发环境,测试环境,生成环境。
2.接口关联: 需要手动关联.
3.参数需要手动修改.

1. 界面导航说明

在这里插入图片描述

导入 导出用例集

1.导出指定用例集
在这里插入图片描述
2.导入用例集
在这里插入图片描述

Get请求和Post请求的区别:

1.get请求一般是获取数据,post请求一般的提交数据。
2.post请求和get请求安全。
3.本质区别是传参的方式不-样:
get请求在地址栏后面以?的方式传参,多个参数之间用&分隔。
post请求是在body以表单的方式传参。

2.postman环境变量和全局变量

环境变量:环境变量就是在特定环境下(生产环境、开发环境、测试环境)生效的变量,在本环境唯一。
在这里插入图片描述
全局变量:全局变量是能够在任何接口里面访问的变量。
获取环境变量和全局变量的值通过: {{变量名}}

3. postman 请求前置脚本

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

Postman内置动态参数以及自定义的动态参数(时间戳)

  1. postman内置动态参数:
    {{$timestamp}} 生成当前时间的时间戳。
    {{SrandomInt}} 生成0-1000之间的随机数
    {{$guid}} 生成GUID字符串。
  2. 自定义动态参数
//手动的获得时间戳
var times = Date.now();
//设置为全局变量
pm.globals.set("times", times);

// 使用:{{times}}

在这里插入图片描述

4. postman断言

常规六种断言

Status code:Code is 200检查返回的状态码是否为200
Response body:Contains string检查响应中包括指定字符串
Response body:Json value check检查响应中其中json的值
Response body : is equal to a string检查响应等于一个字符串
Response headers : Content-Type...检查是否包含响应头Content-Type
Response time is less than 200ms :检查请求耗时小于200ms
在这里插入图片描述
在这里插入图片描述

断言响应状态码
//断言响应状态码是否为200
pm.test("检查返回状态码位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

自定义动态参数(全局变量)断言的方式:

pm.globals.get("times")
globals['times"]
globals.times
在这里插入图片描述

全局断言

如果有多种重复的断言,比如状态断言,可以设置为全局断言。
在这里插入图片描述

5. 接口关联

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

A接口依赖B接口的数据:

  1. 向B接口发送http请求,获取数据
  2. 将数据设置至全局变量(环境变量)中
  3. A接口获取全局变量(环境变量)中数据值,进行使用。

使用json提取器实现接口关联

json校验工具:https://www.bejson.com/
脚本1:

// 第一个接口:
//使用json提取器提取accesss_token值。
//把返回的字符串格式的数据转换成对象的形式。
let res = JSON.parse(responseBody)
//把access_token设置为全局变量
pm.globals.set("access_token", res.access_token);

// 第二个接口:
{{access_ token}}

在这里插入图片描述
在这里插入图片描述
脚本2:

// 获取全部响应结果
var jsonData = pm.response.json()
// 从响应结果中获取token
var access_token = jsonData.access_token
// 将token写入到全局变量
pm.globals.set("access_token",access_token)

使用正则表达式提取器实现接口关联

脚本:

// 第一个接口:
//使用正则表达式提取器实现接口关联, match匹配。
let res = responseBody.match(new RegExp('"access_token":(.+?),'))
//设置为全局变量
pm.globals.set("access_token", res[1]);

// 第二个接口:
{{access_ token}}

在这里插入图片描述

案例

请求获取天气接口,提取响应结果中的城市,将城市名,给百度搜索接口使用。
实现步骤:
1.创建用例集,分别创建查询天气请求和百度搜索的请求
在这里插入图片描述
2.在查询天气请求Tests中,编写代码获取城市名,写入全局变量
在这里插入图片描述
3.点击Send按钮,发送请求,查看设置的全局变量。
在这里插入图片描述
4.修改百度搜索请求,使用全局变量,按城市名进行搜索。
在这里插入图片描述

6. 测试必须带请求头的接口

常见的请求头:
Host 请求的主机地址
Connection 连接方式
Accept 客户端接收到的数据格式
X-Requested-With 异步请求
User-Agent 客户端的用户类型
Referer 来源
Cookie Cookie信息
Content-Type :请求内容的格式

7. Postman接口Mock Servier服务器

mock模拟
后端的接口还没有开发完成,前端的业务需要调用后端的接口。

  1. 创建服务器
    在这里插入图片描述
    在这里插入图片描述
  2. 自行设置返回格式
    {“error_code”:0,msg:“返回成功”,data:[]}
    在这里插入图片描述

8. 接口加密

base64
MD5 (最多)

var user = CryptoJS.MD5 ("admin").toString().toUpperCase();
var pass = CryptoJS.MD5("123").toString().toUpperCase();
pm.globals.set("user",user);
pm.globals.set("pa33",pass);

RSA
DES
AES
SHA
自定义加密算法
接口签名(难度系数高,金融项目,支付项目,银行项目,电信项目)

9. 批量执行用例集

步骤:
在这里插入图片描述
在这里插入图片描述

10. 接口测试报告

安装postman的插件newman:前提安装好node.js
npm i -g newman
newman -v 查看版本
安装newman的插件:npm i -g newman-reporter-html

使用newman生成测试报告

使用newman命令,运行导出的测试集脚本,打开cmd输入:
newman run 测试脚本文件 -e 环境变量文件 -d 外部数据文件 -r html --reporter-html-export 测试报告名.html(完整命令)
eg:
newman run demo.postman_collection.json -r html
newman run demo.postman_collection.json -r html --reporter-html-export report.html

生成 环境 下的测试报告

  1. 导出用例集
  2. 导出环境文件
    在这里插入图片描述
  3. 执行生成测试报告的命令
    newman run 用例集名称.json -e 环境变量文件 -r html --reporter-html-export 报告名称.html

11. poatman参数化

poatman参数化就是读取外部数据文件
当http请求,使用的数据有较高相似度时,相同的请求时,考虑使用参数化 (将数据组织到数据文件中)

数据文件常用的两种文件:

  • CSV
    优点: 数据组织形式简单,适用于大量数据的场合。
    缺点:
    1.不支持bool类型数据。(数据被 postman读入后,自动添加 “” 包裹bool值。)
    2.不支持多参、少参、无参、错误参数的接口测试。
    3.不支持复杂数据类型。(如 嵌套字典、列表等)
  • JSON
    优点:
    1.支持bool类型。
    2.支持多参、少参、无参、错误参数。
    3.支持复杂数据类型。
    缺点: 对于相同数据量,json数据文件大小远大于CSV文件。

格式:
在这里插入图片描述

1. 导入外部数据文件(CSV / JSON)

CSV文件

  1. 创建 xxx.csv 文件。
  2. 将数据写入到csv文件中。
  • 第一行写入的是数据对应的"字段名”。
  • 从第二行向后依次是对应的数值,数据间用英文逗号隔分
    在这里插入图片描述
  1. 在Postman中,选中使用数据文件的用例集,导入数据文件。
    1.点击用例集名称,使用Run按钮,进入"Runner"页面。
    2.使用"Select File"按钮选择xxx.csV文件。
    3.点击预览按钮,校验数据文件是否正确
    在这里插入图片描述
    在这里插入图片描述

JSON文件
用在线书写 json代码工具:https://www.json.cn/
为保证json文件书写正确再贴入记事本

  1. 创建xxx.json数据文件
  2. 在数据文件中,按json语法写入json数据。postman要求, json格式的数据文件,数据内容的最外层,必须是[ ]。内部所有的数据用{ }存储。
  3. 在Postman中,选中使用数据文件的用例集,导入数据文件。
    1.点击用例集名称,使用Run按钮,进入"Runner"页面。
    2.使用"Select File"按钮选择xxx.csV文件。
    3.点击预览按钮,校验数据文件是否正确

特性1: postman会循环一行一行的读取{}中的数据。
特性2:建议书写json数据时,无论是不是字符串,都可以用 “” 包裹value的值。

2. 读取数据文件数据

根据使用数据位置不同,有两种获取数据文件中数据的方法。

  • 第一种:请求参数(请求行、请求头、请求体)中,使用数据文件中的数据
    使用{{}}包裹 csv文件字段名 或 json文件中的key
    如: {{username}}{{password}}
  • 第二种:代码(断言、请求前置脚本)中,使用数据文件中的数据
    需要借助postman提供的关键字 data点csv文件的字段名 或 json文件的key
    如: data.usernamedata.password

案例:按手机号找运营商

在这里插入图片描述

  1. 测试单个接口,工作中参数和响应体数据对应关系。
    在这里插入图片描述
  2. 写好数据文件,按csv或json对应语法的语法格式组织数据。
    在这里插入图片描述
  3. 替换:上述用例中的两处:
    1.归属地:在代码中,用 data.字段名替换
    2.手机号:在查询参数中, 用 {{字段名}}替换。
    在这里插入图片描述

强调:一旦替换完成,Send 就不再能正常获取响应数据。(数据必须从数据文件中读取,才能正常发送请求,Send 不具备读取数据文件的功能)

  1. 选择使用数据文件的用例集,进入Runher页面。导入数据文件。运行。
    在这里插入图片描述

如果有异常,借助postman的控制台,查看。

  1. 生成测试报告
    步骤:
    1.批量执行测试用例(借助数据文件)
    2.导出测试用例集(建议与 数据文件放在一起)
    3.执行生成测试报告的命令
    newman run 用例集名称.json -d 数据文件名.csv/. json -r html --reporter-html-export 报告名称.html
    在这里插入图片描述

总结:借助数据文件,实现“数据驱动"–>有多少条数据,对应就有多少个http请求。

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

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

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

相关文章

Java微服务分布式分库分表ShardingSphere - ShardingSphere-JDBC

🌹作者主页:青花锁 🌹简介:Java领域优质创作者🏆、Java微服务架构公号作者😄 🌹简历模板、学习资料、面试题库、技术互助 🌹文末获取联系方式 📝 往期热门专栏回顾 专栏…

【算法刷题 | 贪心算法05】4.27(K次取反后最大化的数组和、加油站)

文章目录 8.K次取反后最大化的数组和8.1题目8.2解法:贪心8.2.1贪心思路8.2.2代码实现 9.加油站9.1题目9.2解法:贪心9.2.1贪心思路9.2.2代码实现 8.K次取反后最大化的数组和 8.1题目 给你一个整数数组 nums 和一个整数 k ,按以下方法修改该数…

基于EBAZ4205矿板的图像处理:03使用VIO调试输出HDMI视频图像

基于EBAZ4205矿板的图像处理:03使用VIO调试输出HDMI视频图像 在zynq调试时VIO是真的方便,特此写一篇博客记录一下 先看效果 项目简介 下面是我的BD设计,vtc用于生成时序,注意,2021.2的vivado的vtcIP是v6.2版本&…

【算法】【贪心算法】【leetcode】870. 优势洗牌

题目地址:https://leetcode.cn/problems/advantage-shuffle/description/ 题目描述: 给定两个长度相等的数组 nums1 和 nums2,nums1 相对于 nums2 的优势可以用满足 nums1[i] > nums2[i] 的索引 i 的数目来描述。 返回 nums1 的任意排列&…

C++入门基础(二)

目录 缺省参数缺省参数概念缺省参数分类全缺省参数半缺省参数声明与定义分离 缺省参数的应用 函数重载函数重载概念例子1 参数类型不同例子2 参数的个数不同例子3 参数的顺序不同 C支持函数重载的原理--名字修饰(name Mangling) 感谢各位大佬对我的支持,如果我的文章对你有用,欢…

nginx+Tomcat动静分离

本⽂的动静分离主要是通过nginxtomcat来实现,其中nginx处理图⽚、html等静态的⽂ 件,tomcat处理jsp、do等动态⽂件. 实验环境 192.168.200.133 nginx反向代理 192.168.200.129 static 192.168.200.130 dynamic 步骤 修改三台主机名 [rootadmin ~]#…

《Redis使用手册之列表》

《Redis使用手册之列表》 目录 **《Redis使用手册之列表》****LPUSH:将元素推入列表左端****LPUSHX、RPUSHX:只对已存在的列表执行推入操作****LPOP:弹出列表最左端的元素****RPOP:弹出列表最右端的元素****RPOPLPUSH:…

【C语言刷题系列】删除公共元素

目录 一、问题描述 二、解题思路 三、源代码实现 解决方案一:拷贝到临时数组 解决方案二:直接打印 个人主页: 倔强的石头的博客 系列专栏 :C语言指南 C语言刷题系列 一、问题描述 二、解题思路 第一种方法&…

线上告警炸锅!FastJson 又立功了。。

前段时间新增一个特别简单的功能,晚上上线前review代码时想到公司拼搏进取的价值观临时加一行log日志,觉得就一行简单的日志基本上没啥问题,结果刚上完线后一堆报警,赶紧回滚了代码,找到问题删除了添加日志的代码&…

3.C++动态内存管理(超全)

目录 1 .C/C 内存分布 2. C语言中动态内存管理方式:malloc/calloc/realloc/free 3. C内存管理方式 3.1 new/delete操作内置类型 3.2 new和delete操作自定义类型 3.3 operator new函数 3.4 定位new表达式(placement-new) (了解) 4. 常…

iA Writer for Mac:简洁强大的写作软件

在追求高效写作的今天,iA Writer for Mac凭借其简洁而强大的功能,成为了许多作家、记者和学生的首选工具。这款专为Mac用户打造的写作软件,以其独特的设计理念和实用功能,助你轻松打造高质量的文章。 iA Writer for Mac v7.1.2中文…

C语言(操作符)1

Hi~!这里是奋斗的小羊,很荣幸各位能阅读我的文章,诚请评论指点,关注收藏,欢迎欢迎~~ 💥个人主页:小羊在奋斗 💥所属专栏:C语言 本系列文章为个人学习笔记&#x…

vue2迁移到vue3,v-model的调整

项目从vue2迁移到vue3,v-model不能再使用了,需要如何调整? 下面只提示变化最小的迁移,不赘述vue2和vue3中的常规写法。 vue2迁移到vue3,往往不想去调整之前的代码,以下就使用改动较小的方案进行调整。 I…

Java并发编程面试问题与答案

1. 什么是线程安全? 答: 线程安全意味着多个线程可以同时访问一个类的实例而不引起任何问题或不一致的结果。线程安全的代码会通过同步机制来确保所有线程都能正确地访问共享资源。 2. 解释Java中的synchronized关键字。 答: synchronized…

Q1营收稳健增长,云从科技如何在“百模大战”的险中求稳?

自从迈入大模型时代,AI行业可谓“一天一个样”。越来越多的企业涌现,舆论热议从未断绝。 但就像所有技术必须经历的那些考验,在现实尺度下,AI顺利走进商业化世界,仍然是少部分玩家掌握的稀缺能力。个中原因不尽相同&a…

解决“未能正确加载QtVsToolPackage包“问题

今天,在使用VS2019Qt插件时,弹出"未能正确加载QtVsToolPackage包"错误,如图(1.1)所示: 图(1.1) 报"未能正确加载QtVsToolsPackage包"错误 出现这种现象的原因是: qt-vsaddin升级失败或者版本不兼容&#xff0…

动手学深度学习3.6 softmax回归的从零开始实现-笔记练习(PyTorch)

以下内容为结合李沐老师的课程和教材补充的学习笔记,以及对课后练习的一些思考,自留回顾,也供同学之人交流参考。 本节课程地址:Softmax 回归从零开始实现_哔哩哔哩_bilibili 本节教材地址:3.6. softmax回归的从零开…

物联网实战--平台篇之(二)基础搭建

目录 一、Qt工程创建 二、数据库知识 三、通信协议 四、名词定义 本项目的交流QQ群:701889554 物联网实战--入门篇https://blog.csdn.net/ypp240124016/category_12609773.html 物联网实战--驱动篇https://blog.csdn.net/ypp240124016/category_12631333.html 一、Qt工程…

GoLang Gin实际使用

所有代码同步到Admin/gitDemo - Gitee.comhttps://gitee.com/mec-deployment-team_0/git-demo/tree/dev/ 1.创建Gin框架 一般设计一个常规的web项目,都需要以下几个模块 runApp 主函数,运行整个项目routes 路由控制,管理跳转以及路由分组co…

kubectl_入门_Pod调整

Pod调度 在默认情况下,一个pod在哪个node节点上运行,是由scheduler组件采用相应的算法计算出来的,这个过程是不受人工控制的。 但是在实际过程中,这并不满足需求,因为很多情况下,我们想控制某些pod到达某…