下载地址: ​​http://www.downza.cn/soft/205171.html​

【Python接口自动化测试】Postman使用简介_环境变量

工具栏

  • New: 新建,可以新建Request请求,Collection请求集,环境等等
  • Import: 导入,可以导入别人导出的请求集
  • Runner: 运行一个请求集(批量执行)
  • Invite: 邀请(需要注册,邀请进行协作)
  • 同步图标: (需要注册,同步你的项目到云端)
  • 抓包图标: 抓包/捕获请求,用于开启Postman代理, 手动设置代理(或手机代理)后可抓包/录制请求
  • 设置图标: Postman设置
  • 消息图标: 官方及协助消息
  • 收藏图标: 我的收藏(需要注册)
  • 云端图标: 用户云端数据(需要注册)

接口管理区

  • History: 请求历史记录,可以查询到之前的请求记录
  • Collections: 接口集,相当于一个接口项目或测试计划,接口集中可以建立无限极子文件夹,用于对接口进行分组管理

环境管理区

  • 环境切换:用于切换环境
  • 环境预览:用于快速预览环境中的所有变量
  • 环境管理:用于添加修改环境及环境变量,以及全局变量

什么是环境

接口完整地址 = 服务地址 + 接口地址, 如


Copy

www.sojson.com + /open/api/weather/json.shtml


环境是一套配置,包含许多环境变量。在接口测试中,根据部署在不同的服务器上,服务器地址有可能不同,而同一个接口,接口地址是不变的。为了测试部署在不同服务器上的同一套接口,我们可以建立不同的环境,不同环境中host变量使用不同的地址

接口设计区

可以通过上方tab边上的+号,新建多个请求。接口设计区从上到下分为请求区和响应区

  • 请求区
  • 请求地址行:可以选择请求方法(GET/POST/...),填写请求地址,发送请求和保存请求到测试集
  • 请求数据区:分为授权,请求头,请求数据,请求发送前执行的脚本(用于准备数据),请求结束后执行的脚本(用于断言)
  • 响应区:
  • 响应内容: 可以查看Pretty(美化格式),Raw(原始格式),Preview(HTML预览格式)
  • 响应Cookie
  • 响应头
  • 测试结果,对应请求中Tests中设置的断言

【Python接口自动化测试】Postman使用简介_json_02

Collection请求集

测试集是Postman中接口管理的一个“整体”单位,运行、导出、分享等都是基于测试集的。

  • 新建测试集: New按钮->Collection 或 直接点击测试集列表上方的新建测试集按钮
  • 授权: 测试集及其子文件夹下的接口统一使用该授权,不用每个接口再都单独设置一遍
  • 请求前脚本: 测试集的每个接口公用的请求前脚本
  • 请求后断言: 测试集每个接口公用的请求后脚本
  • 请求集变量: 请求集中公用的一些变量
  • 子文件夹
    子文件夹的属性中同样拥有描述,授权,请求前脚本,和请求后断言(没有变量,一个请求集的变量统一管理),实现了不同范围(Scope)的Fixture功能。
  • 请求集导出:请求集可以导出并发送给别人(不携带环境信息),别人通过导入来使用你的接口
  • 请求集分享: 请求集直接分享给别人(双方都需要注册)

** 环境管理**

【Python接口自动化测试】Postman使用简介_请求数据_03

我们可以环境中设置多个变量,以供在请求中使用

环境变量使用方法:

选择环境,在请求URL或者请求Body里使用{{变量名}}来使用环境变量,变量可以在请求Body的各种格式中使用,但不能直接在请求前脚本(Pre-request Script)和请求后脚本(Tests)中使用

【Python接口自动化测试】Postman使用简介_环境变量_04

环境管理中还可以点击“Global”添加全局变量,环境变量只有当选择了该环境时生效,全局变量在任何环境中生效,测试集中的变量只在当前测试集生效,当测试集变量,环境变量,全局变量有重复的变量名时,优先级为:环境变量>全局变量>测试集变量

Params使用

当请求URL中参数很多时,不方便进行添加和查看,可以点击URL输入框后的Params按钮,以表格的方式添加变量及值,从表格添加后,变量和值会自动添加到URL中

【Python接口自动化测试】Postman使用简介_请求数据_05

请求设计

  • 授权:如果接口需要授权,可以在该页面设置授权方式(type)和授权信息
  • Header: 请求头,可以设置请求类型(Content-Type)和Cookie
  • Body: 请求数据
  • form-data:混合表单,支持上传文件
  • x-www-form-urlencoded:文本表单
  • raw:原始格式,支持JSON/XML格式(后面可选择)
  • binary: 二进制格式,用于发送二进制数据流
  • Pre-request Script: 请求前脚本,Javascript语法,用于在发送请求前生成一些动态数据或做一些处理
  • Tests:请求后脚本,Javascript语法,用于请求返回后做一些处理或断言结果

Postman发送各种格式请求的方法:

注意:选择不同的请求可是,会自动在Header中添加Content-Type信息

【Python接口自动化测试】Postman使用简介_json_06

【Python接口自动化测试】Postman使用简介_json_07

【Python接口自动化测试】Postman使用简介_html_08

【Python接口自动化测试】Postman使用简介_html_09

Tests断言

  • HTTP状态码断言:


Copy

tests["HTTP状态码200"]=responseCode.code == 200;


  • 响应包含内容断言:


Copy

tests["状态码200"] = responseBody.has("登录成功");


接口样例:

POST ​​https://demo.fastadmin.net/admin/index/login.html​​ 用户名/密码: admin/123456

【Python接口自动化测试】Postman使用简介_html_10

【Python接口自动化测试】Postman使用简介_环境变量_11

  • JSON响应断言


Copy

var jsonData = JSON.parse(responseBody);
tests["code为200"] = jsonData.code==200
tests["msg为success"] = jsonData.msg == "success"


接口样例:

GET ​​http://www.tuling123.com/openapi/api?key=ec961279f453459b9248f0aeb6600bbe&info=你好​

【Python接口自动化测试】Postman使用简介_请求数据_12

Runner: 测试集批量执行

  • 支持设置迭代次数
  • 支持加载csv或json类测试数据

操作方法:

如https://demo.fastadmin.net/admin/index/login.html接口

  • 新建一个Collection,比如名称Demo2
  • 填入URL:​​https://demo.fastadmin.net/admin/index/login.html,​​ 选择POST方法
  • 请求数据(Body)格式选x-www-form-urlecoded,请求数据填写username {{username}} password {{password}},这里使用了两个变量来做参数化

【Python接口自动化测试】Postman使用简介_请求数据_13

  • 保存请求到Demo2中
  • 在电脑上新建一个data.csv文件,第一行为变量名,下面是数据,如下图

【Python接口自动化测试】Postman使用简介_json_14

  • 点击Postman工具栏的Runner按钮,Collection选择Demo2, Data选择数据文件data.csv, 点击运行Demo2

【Python接口自动化测试】Postman使用简介_html_15

【Python接口自动化测试】Postman使用简介_html_16