7.4 postman接口测试(补充)

1、基础应用

1.1 接口测试的简介和分类

 接口测试就是测试系统组件接口之间的一种测试

分类:

测试外部接口:测试被测系统和外部系统之间的接口(只需要测试正例即可)

测试内部接口

  ①内部接口只提供给内部系统使用(预算系统,承保系统)(只需要测试正例即可)
  ②内部接口提供给外部系统使用(测试必须非常全面,正例,各种异常场景,权限控制)

1.2 接口测试的流程以及用例的设计

 ①拿到接口api文档(通过抓包工具获取),熟悉接口业务,接口地址,鉴权方式,入参,出参,错误码

 ②编写接口用例以及评审

思路:

正例:输入正常入参,接口能够成功返回数据

反例

  鉴权反例:
   鉴权码为空,鉴权码错误,鉴权码过期…

  参数反例:
   参数为空,参数类型异常,参数长度异常

  错误码覆盖:
   根据业务而定的

  其他错误场景:
   接口黑名单,接口调用次数限制,分页场景
在这里插入图片描述
 ③使用接口测试工具postman执行接口测试

 ④postman+newman+jenkins实现持续集成,并且输出测试报告,且发送邮件

1.3 实战-微信公众平台接口

获取权限:
 appid

 secret(秘钥)

1.4 postman界面功能介绍

 Home-主页

 Workspaces-工作空间
  Collections:集合,项目集合
  APIS:api文档
  Environments:环境变量,全局变量
  Mock Server:虚拟服务器
  Monitors:监听器
  History:历史记录

1.5 postman执行接口测试

请求页签:

 Params:get请求传参

 Authorizition:鉴权

 Headers:请求头

 Body:post请求传参
  none(不常用):没有参数
  form-data:既可以传键值对参数,也可以传文件
  x-www-form-urlencoded:只能传键值对参数
  raw:json,text,xml,html,javaScript
  binary:把文件以二进制的方式传参

 Pre-request-script:请求之前的脚本

 Tests:请求之后的断言

 Settings:设置

 Cookies:用于管理cookie信息

响应页签:

 Body:接口返回的数据
  Pretty:以json,html,xml…不同的格式查看返回的数据
  Raw:以文本的方式查看返回的数据
  PreView:以网页的方式查看返回的数据

 Cookies:响应的Cookie信息

 Headers:响应头

 Test Results:断言的结果

 200-状态码
 OK-状态信息

 681ms:响应时间

 343B:响应的字节数

Get请求和Post请求的区别:

 ①get请求一般是获取数据,post请求一般是提交数据

 ②post请求比get请求安全

 ③本质区别是传参方式不同:
  get请求在地址栏后面以?的方式传参,多个参数用&分隔
  post请求是在body以表单的方式传参

问题:

 多种环境:开发环境,测试环境,生产环境
 接口关联:需要手动关联
 参数需要手动修改

1.6 postman的环境变量及全局变量

环境变量:环境变量就是全局变量
全局变量:能够在任何接口中访问的变量

获取环境变量和全局变量的值是通过:{{变量名}}

1.7 接口关联

1.7.1 json提取器实现接口关联

第一个接口:

console.log(responseBody);
//使用json提取器提取access_token值
//把返回的字符串格式的数据转换成对象的形式
var result = JSON.parse(responseBody);
console.log(result.access_token);
//把access_token设置为全局变量
pm.globals.set("access_token", result.access_token);

第二个接口:

{{access_token}}

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

第一个接口:

//使用正则表达式提取器实现接口关联,match匹配
var result = responseBody.match(new RegExp('"access_token":"(.*?)"'));
console.log(result[1]);
//设置为全局变量
pm.globals.set("access_token", result[1]);

在这里插入图片描述
第二个接口:

{{access_token}}

1.8 postman内置动态参数以及自定义的动态参数

1.8.1 内置动态参数

 {{$timestamp}}:生成当前时间的时间戳

 {{$randomint}}:生成0-1000之间的随机数

 {{$guid}}:生成速记GUID字符串

1.8.2 自定义动态参数

在这里插入图片描述
使用时:{{times}}

1.9 测试其他接口

get请求:在Params中编写内容
post请求:在Body中编写
增删改查:需要形成一个闭环
文件上传:在Body中的form-data中选择file

1.10 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

 Responsetime is less than 200ms:检查请求耗时小于200ms
在这里插入图片描述
自定义动态断言:
在断言中获取自定义动态参数(全局变量)的方式:

①pm.globals.get("times")
②globals["times"]
③globals.times

全局断言:
在这里插入图片描述

1.11 postman批量运行测试用例

在这里插入图片描述

1.12 postman数据驱动之CSV文件和JSON文件的处理

1.13 测试必须带请求头的接口

常见的请求头:

 Host:请求的主机地址

 Collection:连接方式

 Accept:客户端收到的数据格式【常用】

 X-Requested-With:异步请求【常用】

 User-Agent:客户端的用户类型【常用】

 Referer:来源

 Cookie:Cookie信息【常用】

 Content-Type:请求内容的格式【常用】

1.14 postman接口Mock Server服务器

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

{“error_code”:0,msg:“返回成功”,data:[]}

1.15 postman的Cookie鉴权

什么是cookie?

 cookie是一小段文本,格式:key = value

cookie鉴权的原理:【重要】

 ①当客户端第一次访问服务器时,服务器就会生成cookie信息,且在响应头的set-cookie中把生成的cookie信息发送给客户端

 ②当客户端第2-N次访问服务器时,客户端会在请求头的cookie带上cookie信息,从而实现鉴权

cookie的分类:

 ①会话cookie:保存在内存,当浏览器关闭后会自动化消除cookie

 ②持久cookie:保存在硬盘,浏览器关闭后不会清除,只有当失效时间到了才会自动清除

1.16 Newman

postman专门为接口测试而生,newman转为postman而生,newman可以让postman的脚本通过非GUI(命令行)的方式去运行

 运行命令:newman run

常用参数:

 -e:引用环境变量

 -g:引用全局变量

 -d:引用数据文件

 -n:指定测试用例迭代次数

 -r cli,html,json,junit --reporter-html-export:指定生成HTML的报告
在这里插入图片描述

1.17 postman+newman+Jenkins实现接口测试持续集成

 ①新建一个项目

 ②设置自定义工作空间

 ③执行windows的批处理命令
在这里插入图片描述
 ④执行系统的Groovy脚本
在这里插入图片描述
 ⑤生成的HTML的报告集成到Jenkins
在这里插入图片描述

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇
下一篇>>