postman接口功能测试
前言
之前还没实际做过接口测试的时候呢,对接口测试这个概念比较渺茫,只能靠百度,查看各种接口实例,然后在工作中也没用上,现在呢是各种各样的接口都丢过来,总算是有了个实际的认识。虽然只是接口功能的测试,但是也要记录下自己学到的点滴技能。
因为只是接口的功能测试,所以目前是用postman做测试,比较简便,当然这只是接口测试的入门而已,了解的只是冰山一角,后续会努力往接口压力、接口性能、接口自动化方向靠拢。(postman的安装方法可以百度一下,这里就不提了)
各位大佬勿喷哈~
接口理论
接口实例
一、POST
POST请求是用来发送数据的,下面以下XX系统分配加工厂为例
1、产品经理的PRD文档要求如下(分配加工厂接口的修改内容如下):
1) 分配加工厂接口里新增加工厂ID字段,整数类型,非必填;
2.)若对单领料单已经审核通过,限制只有待审核状态才能分配加工厂,若不是则提示“对单领料单不是待审核,不能分配加工厂”;
2、开发人员的接口文档如下:
接口名称:XX系统分配加工厂接口
| 参数名称 | 参数值 | 是否必须 | 示例 | 备注 |
| Content-Type | application/json | 是 |
Body:
{
"factoryId": "",//加工厂ID
"factory": "XX服饰",//加工厂名称
"produce_order_id": [//生产制单(纯数字) 多个用,分开
]
}
返回数据:
{
"msg": "success",
"code": "",
"info": "操作成功"
}
3、测试人员的测试用例如下:
| 用例编号 | 模块 | 用例标题 | 前提条件 | 操作步骤 | 预期结果 |
| 01 | XX接口 | 分配加工厂接口里新增加工厂ID字段,整数类型,非必填 | 填写错误的或类型不对的加工厂ID | 略 | 返回具体的错误信息 |
| 不填写加工厂ID,其他条件符合要求 | 分配加工厂成功,XX系统的领料单正确显示加工厂名称 | ||||
| 填写正确的加工厂ID,其他条件符合要求 | 分配加工厂成功,XX系统的领料单正确显示加工厂名称 | ||||
| 填写正确的加工厂ID,对单领料单已经审核通过 | 返回提示“对单领料单不是待审核,不能分配加工厂”; |
4、测试人员执行测试用例如下:
2)结合测试用例,组合变换参数信息后,查看返回的JSON数据与PRD是否一致
3)测试用例遍历完成后,以上即完成了POST请求的接口功能测试。
4)这里描述一下postman的环境配置
第一步,如图

第二步,如图

第三步,如图

第四步,如图

第五步,如图(这是针对有多个环境的情况,比如一般都会有测试环境、验收环境、生产环境)

二、GET
GET请求是用来获取数据的,下面以XX系统获取出库账单为例,(以下只列出部分数据信息用于演示)
1、产品经理的PRD文档要求如下:
| 输入参数 | |||
| 字段名称 | 是否必填 | 取值逻辑 | 备注说明 |
| 账单日期 | 是 | 例如2019-04-10 | |
| 供应商ID | 否 | ||
| 输出参数 | |||
| 账单编号 | 是 | ML+年月日+流水号 | 一个账单日期内,一个供应商只对应一个账单 |
| 账单日期 | 是 | 输入参数里的账单日期 | |
| 供应商名称 | 是 | 从出库单获取 | |
| SKU | 是 | 从出库单明细获取 | |
| 采购单价 | 是 | 根据SKU获取档案的基准价 | |
| 数量 | 是 | 出库数量 | |
| 账单金额 | 是 | 采购单价*数量,金额为负 | |
2、开发人员的接口文档如下:
接口名称:出库账单同步到XX系统接口
| 参数名称 | 是否必须 | 示例 | 备注 |
| billDate | 是 | 2019-02-20 | 账单日期 |
| supplierId | 否 | 1 | 供应商ID |
{
"msg": "success",
"code": "",
"info": {
"list": [
{
"billNo": "ML201902205005", //账单编号
"billDate": "2019-02-20", //账单日期
"factory": "生产部萨文服饰-烨琳", //供应商名称
"materialSku": "16MLZS0513-628", //物料SKU
"num": , //数量
"purchasePrice": , //采购单价
"billSum": , //账单金额
}
]
}
}
| 用例编号 | 所属模块 | 用例标题 | 前提条件 | 测试步骤 | 预期结果 |
| 01 | XX接口 | 输入正确的‘账单日期’请求参数,接口正确返回相应的账单数据 | 系统中有在该账单日期内的账单 |
1、在请求地址中增加‘billDate’参数; |
{"msg": "success", "code": "0", "info":….} |
| 02 | XX接口 | 输入不符合规范的‘账单日期’请求参数,接口返回参数不符合要求 | 填写12/23/45 |
1、在请求地址中增加‘billDate’参数; |
{"msg":"账单日期不符合规范;","code":"43"} |
| 03 | XX接口 | 将‘账单日期’请求参数置空,接口返回参数必填 |
1、在请求地址中增加‘billDate’参数; |
{"msg":"账单日期不能为空;","code":"43"} | |
| 04 | XX接口 | ‘供应商ID’请求参数 | 请求中没有‘billDate’ |
1、在请求地址中增加‘supplierId’参数; |
{"msg":"账单日期不能为空;","code":"43"} |
| 05 | XX接口 | 请求中有‘billDate’ |
1、在请求地址中增加‘billDate’,‘supplierId’参数; |
{"msg": "success", "code": "0", "info":….} |
|
| 06 | XX接口 | 请求中有‘billDate’ |
1、在请求地址中增加‘billDate’,‘supplierId’参数; |
{"msg":"供应商ID不存在;","code":"43"} | |
| 07 | XX接口 | 请求中有‘billDate’ |
1、在请求地址中增加‘billDate’,‘supplierId’参数; |
{"msg": "success", "code": "0", "info":….} |
|
| 08 | XX接口 | ‘账单编号’输出参数取值为:ML+年+月+日+4位流水号 | 接口返回正确数据 | 1.GET后,查看返回的JSON数据 | ‘账单编号’输出参数取值为:ML+年+月+日+4位流水号 |
| 09 | XX接口 | 以上列举了部分测试用例,其他的测试用例就不再展示了 | |||
2)结合测试用例,组合变换参数信息后,查看返回的JSON数据与PRD是否一致
3)测试用例遍历完成后,以上即完成了GET请求的接口功能测试。
postman接口功能测试的更多相关文章
- 分别用postman和python做post请求接口功能测试
前几天,在做一个post请求的接口功能测试的时候,发现数据始终无法入库, 认真加仔细检查了请求的url.方式.参数,均没有问题 找到技术确认,原来是需要传json格式数据 在头信息中加上类型,body ...
- 学习总结——JMeter做http接口功能测试
JMeter对各种类型接口的测试 默认做接口测试前,已经给出明确的接口文档(如,http://test.nnzhp.cn/wiki/index.php?doc-view-59):本地配好了JMeter ...
- 黑羽压测 做 API接口功能测试
做功能测试 黑羽压测 是一款性能测试工具,但是我们也可以使用它,很方便的做 API接口功能测试 . 点击下方链接,观看 讲解视频 https://www.bilibili.com/video/av60 ...
- Postman接口自动化测试实例二
在<Postman接口自动化测试实例>一文中,我是在获取随机因子的接口的Tests中对用户的密码进行加密处理的.其实正常做法应该是在请求验证接口前,即在Pre-request Script ...
- 接口自动化测试持续集成--Soapui接口功能测试持续集成
Soapui接口功能测试持续集成,需要先安装好maven和jenkins,maven和jenkins安装和系统环境配置比较简单,在这里不做叙述. 1.Soapui保存的工程文件 soapui工程保 ...
- Postman接口自动化--Postman Script脚本功能使用详解
Postman Script 功能,支持原生的JS,所以可以使用JS解决很多接口自动化的一些问题,例如接口依赖.接口参数专递和接口断言等: 这里主要是针对Pre-Request Script 和 Te ...
- Postman接口&压力测试
Postman接口与压力测试实例 Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件.它提供功能强大的 Web API & HTTP 请求调试. 1.环境变量和全局 ...
- API Test Postman接口测试之高级篇2
API Test Postman接口测试之高级篇2 一.继承父类的设置: 二.导出及导入: 三.分享文档: 四.发布接口文档: 五.常用脚本: 右边框选的是一些常用的脚本,postman提供的,可以 ...
- API Test Postman接口测试之高级篇1
API Test Postman接口测试之高级篇1 一.postman中的请求参数简介: 1.请求参数简介: 点击params下面会出现key,value等信息,这里填写的会自动追加在url地址后面 ...
随机推荐
- 字典的增删改查 daty 5
字典:python中非常重要的数据类型,在python中唯一一个映射的数据类型数据类型分类 按照数据可变与不可变: # 不可变数据类型: int str bool tuple # 可变数据类型: li ...
- 自适应手机网站meta name代码
<meta name="viewport" content="width=device-width,initial-scale=1.0"> co ...
- 同一个线程多次调用start()会出现的问题
结果: 线程首先会运行一次,然后抛出java.lang.IllegalThreadStateException异常. 根据控制台的异常信息,定位到Thread.java的第708行,也就start() ...
- iOS.GetCurrentTimestamp
Cocoa 中测量时间的方法 1. The Methods to Get Current Timestamp iOS中获取时间戳的方法: A. CACurrentMediaTime() B. gett ...
- How to use bmw icom a2
Lan Connect Operation Details 1. Connect the LAN cable to ICOM A1/ICOM A2, another side to laptop LA ...
- 多字节字符集与Unicode字符集
在计算机中字符通常并不是保存为图像,每个字符都是使用一个编码来表示的,而每个字符究竟使用哪个编码代表,要取决于使用哪个字符集(charset). 多字节字符集: 在最初的时候,Internet上只有一 ...
- Java中创建对象的四种方法
第一种 使用new关键字 第二种 使用反射技术:1)通过Class类的newInstance()方法:2)通过Constructor类的newInstance方法 第三种 通过Object类的clon ...
- [Robot Framework] 如何在Setup中用Run Keywords执行多个带参数的关键字
参考文档:http://www.howtobuildsoftware.com/index.php/how-do/bZ7q/robotframework-setup-teardown-robot-fra ...
- boost timer代码学习笔记
socket连接中需要判断超时 所以这几天看了看boost中计时器的文档和示例 一共有五个例子 从简单的同步等待到异步调用超时处理 先看第一个例子 // timer1.cpp: 定义控制台应用程序的入 ...
- springMVC学习二 原始springMVC环境搭建
第一步:导入jar包 第二步:配置DispatcherServlet DispatcherServlet本质是一个Servlet,在spring-webmvc包中,在servlet2.5之前 spr ...