当前位置: 首页 > news >正文

postman接口功能测试

前言             

1小时postman接口测试从入门到精通教程

                                          

  之前还没实际做过接口测试的时候呢,对接口测试这个概念比较渺茫,只能靠百度,查看各种接口实例,然后在工作中也没用上,现在呢是各种各样的接口都丢过来,总算是有了个实际的认识。虽然只是接口功能的测试,但是也要记录下自己学到的点滴技能。

  因为只是接口的功能测试,所以目前是用postman做测试,比较简便,当然这只是接口测试的入门而已,了解的只是冰山一角,后续会努力往接口压力、接口性能、接口自动化方向靠拢。(postman的安装方法可以百度一下,这里就不提了)

  各位大佬勿喷哈~

接口理论                                                 

  我们常说的接口就是API,接口测试是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等。

  其实接口测试就和普通功能测试没什么区别,区别就是功能测试是在页面上输入值,提交数据看结果,而接口测试没有页面,通过接口规范文档上的调用地址,请求参数,拼接报文,然后发送请求,检查返回结果。

  

接口实例                                                

一、POST

POST请求是用来发送数据的,下面以下XX系统分配加工厂为例

1、产品经理的PRD文档要求如下(分配加工厂接口的修改内容如下):

1) 分配加工厂接口里新增加工厂ID字段,整数类型,非必填;

2.)若对单领料单已经审核通过,限制只有待审核状态才能分配加工厂,若不是则提示“对单领料单不是待审核,不能分配加工厂”;

2、开发人员的接口文档如下:

接口名称:XX系统分配加工厂接口

接口路径:POST  /process/requisitionOrder/updateDistributeStatus

请求参数:

Headers:

参数名称参数值是否必须示例备注
Content-Typeapplication/json

Body:

复制代码

{"factoryId": "123",//加工厂ID"factory": "XX服饰",//加工厂名称"produce_order_id": [//生产制单(纯数字) 多个用,分开1134360]
}

复制代码

返回数据:

{"msg": "success","code": "0","info": "操作成功"
}

3、测试人员的测试用例如下:

用例编号模块用例标题前提条件操作步骤预期结果
01XX接口分配加工厂接口里新增加工厂ID字段,整数类型,非必填填写错误的或类型不对的加工厂ID返回具体的错误信息
不填写加工厂ID,其他条件符合要求分配加工厂成功,XX系统的领料单正确显示加工厂名称
填写正确的加工厂ID,其他条件符合要求分配加工厂成功,XX系统的领料单正确显示加工厂名称
填写正确的加工厂ID,对单领料单已经审核通过返回提示“对单领料单不是待审核,不能分配加工厂”;

4、测试人员执行测试用例如下:

1)打开Postman,填写接口信息,具体操作如图

注:接口文档中的URL是不带环境地址的,所以将URL复制到地址栏时,前面还要加上环境的地址,比如测试环境的地址+接口URL,

当然如果有多个环境的话,可以用环境配置功能,具体配置步骤在第4)步进行描述。

2)结合测试用例,组合变换参数信息后,查看返回的JSON数据与PRD是否一致

3)测试用例遍历完成后,以上即完成了POST请求的接口功能测试。

4)这里描述一下postman的环境配置

第一步,如图

第二步,如图

第三步,如图

第四步,如图

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

二、GET

GET请求是用来获取数据的,下面以XX系统获取出库账单为例,(以下只列出部分数据信息用于演示)

1、产品经理的PRD文档要求如下:

输入参数
字段名称是否必填取值逻辑备注说明
账单日期例如2019-04-10
供应商ID
输出参数
账单编号ML+年月日+流水号一个账单日期内,一个供应商只对应一个账单
账单日期输入参数里的账单日期
供应商名称从出库单获取
SKU从出库单明细获取
采购单价根据SKU获取档案的基准价
数量出库数量
账单金额采购单价*数量,金额为负

2、开发人员的接口文档如下:

接口名称:出库账单同步到XX系统接口

接口路径:GET  /purchase/prepareOrder/importListFromPlm

请求参数:

Query:

参数名称是否必须示例备注
billDate2019-02-20账单日期
supplierId1供应商ID

返回数据:

复制代码

{"msg": "success","code": "0","info": {"list": [{"billNo": "ML201902205005",         //账单编号"billDate": "2019-02-20",           //账单日期"factory": "生产部萨文服饰-烨琳",   //供应商名称"materialSku": "16MLZS0513-628",    //物料SKU"num": 20,                          //数量"purchasePrice": 0,                 //采购单价"billSum": 0,                       //账单金额}]}
}

复制代码

3、测试人员的测试用例如下:

用例编号所属模块用例标题前提条件测试步骤预期结果
01XX接口输入正确的‘账单日期’请求参数,接口正确返回相应的账单数据系统中有在该账单日期内的账单

1、在请求地址中增加‘billDate’参数;
2、billDate填写正确的账单日期,点击GET

{"msg": "success", "code": "0", "info":….}
info显示正确的账单信息

02XX接口输入不符合规范的‘账单日期’请求参数,接口返回参数不符合要求填写12/23/45

1、在请求地址中增加‘billDate’参数;
2、billDate填写不符合规范的账单日期,点击GET

{"msg":"账单日期不符合规范;","code":"43"}
03XX接口将‘账单日期’请求参数置空,接口返回参数必填

1、在请求地址中增加‘billDate’参数;
2、billDate不填写,点击GET

{"msg":"账单日期不能为空;","code":"43"}
04XX接口‘供应商ID’请求参数请求中没有‘billDate’

1、在请求地址中增加‘supplierId’参数;
2、supplierId填写正确的供应商ID,点击GET

{"msg":"账单日期不能为空;","code":"43"}
05XX接口请求中有‘billDate’

1、在请求地址中增加‘billDate’,‘supplierId’参数;
2、supplierId填写正确的供应商ID,billDate填写正确的账单日期,点击GET

{"msg": "success", "code": "0", "info":….}
info显示正确的账单信息

06XX接口请求中有‘billDate’

1、在请求地址中增加‘billDate’,‘supplierId’参数;
2、supplierId填写错误的供应商ID,billDate填写正确的账单日期,点击GET

{"msg":"供应商ID不存在;","code":"43"}
07XX接口请求中有‘billDate’

1、在请求地址中增加‘billDate’,‘supplierId’参数;
2、supplierId不填写,billDate填写正确的账单日期,点击GET

{"msg": "success", "code": "0", "info":….}
info显示正确的账单信息

08XX接口‘账单编号’输出参数取值为:ML+年+月+日+4位流水号接口返回正确数据1.GET后,查看返回的JSON数据‘账单编号’输出参数取值为:ML+年+月+日+4位流水号
09XX接口以上列举了部分测试用例,其他的测试用例就不再展示了

4、测试人员执行测试用例如下:

1)打开Postman,填写接口信息,具体操作如图

注:接口文档中的URL是不带环境地址的,所以将URL复制到地址栏时,前面还要加上环境的地址,比如测试环境的地址+接口URL,

当然如果有多个环境的话,可以用环境配置功能,具体配置步骤可以参考POST的描述

2)结合测试用例,组合变换参数信息后,查看返回的JSON数据与PRD是否一致

3)测试用例遍历完成后,以上即完成了GET请求的接口功能测试。


文章转载自:

http://P0gRxl9p.bkkgt.cn
http://AzgYIDmS.bkkgt.cn
http://yAOps57V.bkkgt.cn
http://0mIYXwdM.bkkgt.cn
http://X1xAVZJE.bkkgt.cn
http://wLw8mKYB.bkkgt.cn
http://KWX09kha.bkkgt.cn
http://mknVkGVN.bkkgt.cn
http://WXsWct6L.bkkgt.cn
http://jC1x2dtD.bkkgt.cn
http://XK0r1F53.bkkgt.cn
http://zgu6x3c2.bkkgt.cn
http://4rLdVPFd.bkkgt.cn
http://lGXkdeAd.bkkgt.cn
http://XRV3lF5k.bkkgt.cn
http://LGrPWe6Z.bkkgt.cn
http://bPDfIjnf.bkkgt.cn
http://01Bn6Si2.bkkgt.cn
http://hWXe7lCm.bkkgt.cn
http://7DgU0FhJ.bkkgt.cn
http://YjoRyPtP.bkkgt.cn
http://Kp6RADtb.bkkgt.cn
http://AaKwFdrs.bkkgt.cn
http://nkCrx3mV.bkkgt.cn
http://Kauyyveq.bkkgt.cn
http://TFI0xh6H.bkkgt.cn
http://dgRfCG32.bkkgt.cn
http://qaQWy7Lm.bkkgt.cn
http://8mOAAA9N.bkkgt.cn
http://AXMj03gg.bkkgt.cn
http://www.dtcms.com/a/372289.html

相关文章:

  • Java数据结构 - 顺序表模拟实现与使用
  • 【秋招笔试】2025.09.04携程秋招
  • PyPI 镜像源选择与 pipenv/poetry 加速配置(含实战与避坑)
  • 如何设计本地缓存、有哪些坑需要避免
  • 人力资源管理的思维方法学习笔记1
  • 【面试向】边缘计算基础介绍
  • digitalworld.local: TORMENT
  • MySQL数据库专用命令详细使用指南
  • Python3.12-slim版本
  • AI 生成式艺术重塑动漫角色创作:从技术逻辑到多元可能性(三)
  • 【面试向】元宇宙介绍
  • 硬件开发(4)—ARM裸机体系结构
  • Stream API三巨头:filter、map、collect
  • NAS可以干啥?好玩吗?
  • GDAL 在 Python 中的开发起步
  • RK3568编译linux内核遇到问题总结
  • React学习教程,从入门到精通, React 样式语法知识点与案例详解(13)
  • BiFormer注意力机制YOLOV8
  • 【算法】字符串专题
  • 谓语动词选择指南
  • JavaScript常见算法题分类
  • python---多态
  • 中兴B860AV3.2-M/B860AV3.1-M2-内存大小区分参考指南
  • 【开题答辩全过程】以 校园二手货物交易平台为例,包含答辩的问题和答案
  • 【PyTorch】图像多分类部署
  • 阿里云上启动enclave 并与宿主机通信
  • Python 多任务编程:进程、线程与协程全面解析
  • Wan系列模型解析--VACE
  • 关于学习的一些感悟
  • 如何在Python中使用正则表达式替换特定格式的文本?