postman使用
1 界面介绍
2 工具栏
New: 新建,可以新建Request请求,Collection请求集,环境等等
Import: 导入,可以导入别人导出的请求集
Runner: 运行一个请求集(批量执行)
Invite: 邀请(需要注册,邀请进行协作)
同步图标: (需要注册,同步你的项目到云端)
抓包图标: 抓包/捕获请求,用于开启Postman代理, 手动设置代理(或手机代理)后可抓包/录制请求
设置图标: Postman设置
消息图标: 官方及协助消息
收藏图标: 我的收藏(需要注册)
云端图标: 用户云端数据(需要注册)
3 接口管理区
History: 请求历史记录,可以查询到之前的请求记录
Collections: 接口集,相当于一个接口项目或测试计划,接口集中可以建立无限极子文件夹,用于对接口进行分组管理
4 环境管理区
环境变量即为参数化的含义
url,params,body用到环境变量---使用双花括号{{key}},使用时要选择环境变量的设置名称
4 使用文件来引入参数化 ,批量执行(runner:可设置执行的次数,需要有断言test脚本)
环境切换:用于切换环境,一个环境可以配置多个变量
环境预览:用于快速预览环境中的所有变量,点击眼睛的图标
环境管理:用于添加修改环境及环境变量,以及全局变量
postman的变量就是一个字符串标识
全局变量(global):设定的是一个固定值
局部变量(local):多个值,只针对单个环境有效
环境变量的优先级高于全局变量
5 接口设计区
可以通过上方tab边上的+号,新建多个请求。接口设计区从上到下分为请求区和响应区
请求区(request)
请求地址行:可以选择请求方法(GET/POST/...),填写请求地址,发送请求和保存请求到测试集
请求数据区:分为参数(params),授权(authorization),请求头(headers),请求数据(body),请求发送前执行的脚本--pre -request srcipt(用于准备数据--初始化操作),请求结束后执行的脚本--tests(用于断言)
响应区(response)
响应内容: 可以查看Pretty(美化格式),Raw(原始格式),Preview(HTML预览格式)
响应Cookie
响应头
测试结果,对应请求中Tests中设置的断言
6 Collection请求集
测试集是Postman中接口管理的一个“整体”单位,运行、导出、分享等都是基于测试集的。
新建测试集: New按钮->Collection 或 直接点击测试集列表上方的新建测试集按钮
授权: 测试集及其子文件夹下的接口统一使用该授权,不用每个接口再都单独设置一遍
请求前脚本: 测试集的每个接口公用的请求前脚本
请求后断言: 测试集每个接口公用的请求后脚本
请求集变量: 请求集中公用的一些变量--variables
子文件夹
子文件夹的属性中同样拥有描述,授权,请求前脚本,和请求后断言(没有变量,一个请求集的变量统一管理),实现了不同范围(Scope)的Fixture功能。
请求集导出:请求集可以导出并发送给别人(不携带环境信息),别人通过导入来使用你的接口
请求集分享: 请求集直接分享给别人(双方都需要注册)
7 构建http请求
7.1 请求方法:method---get,post,delete,put
7.2 URL:URl参数:query string :www.baidu.com/?a=1&b=2
7.3 请求头(headers)
7.4 消息体(body):get请求没有消息体
请求数据类型(Content-Type)
application/x-www-form-urlencoded: 网页表单格式(默认)
application/json:REST接口常用格式
text/xml:xml格式,RPC接口,Dubbo接口常用格式
test/html: html格式
multipart/form-data: 混合表单,支持上传图片
要在from-data,的key输入file,类似name="file",filename="统信软件.key"
8 发布接口测试文档
postman账户--点击collection--点击...--点击view in web---点击public----点击发布---生产一个公共的api接口地址
9 postman执行流程:
10 pre-request script:(请求前的脚本操作)
10.1 Setting an environment variable:设置环境变量
postman.setEnvironmentVariable("key", "value");
pm.environment.set("variable_key","variable_value");
10.2 Getting an environment variable: 获取环境变量
postman.getEnvironmentVariable("key");
pm.environment.get("variable_key");
10.3 Clear an environment variable---清除环境变量
postman.clearEnvironmentVariable("key");
pm.environment.unset("variable_key");
10.4 Set a global variable—设置全局变量
postman.setGlobalVariable("key", "value");
pm.globals.set("variable_key","variable_value")
10.5 Get a global variable—获取全局变量
postman.getGlobalVariable("key");
pm.globals.get("variable_key");
10.6 Clear a global variable—清除全局变量
postman.clearGlobalVariable("key");
pm.globals.unset("variable_key");
11 获取环境变量或全局变量的值
将环境变量的值赋值给data变量,在body中引data
12 Tests常用检查点:
1 Check if response body contains a string--检查响应体是否包含字符串
tests["响应体包含字符"]=responseBody.has("<!--STATUS OK-->")
2 Check if respons body is equal to a string(检查响应体是否等于字符串)
tests["Body is correct"] = responseBody === "response_body_string"
3 Check for a JSON value(检查响应体的json内容具体的值)
var data = JSON.parse(responseBody);--针对响应体是json,先将json对象转换为JavaScript对象
tests["Your test name"] = data.key === 100;访问对象的属性
tests["your test name"]=data["key"]===100
4 Convert XML body to a JSON object(将XML格式的响应体转换为JSON对象)
var jsonObject = xml2Json(responseBody);
test[xxx]=responseBody.has(xxx)
5 Status code is 200(响应编码为200)
tests["Status code is 200"] = responseCode.code === 200;
6 Response time is less than 200ms(响应时间小于200毫秒)
tests["Response time is less than 200ms"] = responseTime < 200;
7 Response time is within a specific range (lower bound inclusive, upper bound exclusive)-- 响应时间在特定范围内(下界包含,上界不包含)
tests["Response time is acceptable"] = _.inRange(responseTime, 100, 1001); ---不包含1001ms,包含100ms
8 Code name contains a string—(代码名包含一个字符串)
tests["Status code name has string"] = responseCode.name.has("Created");
9 Content-Type is present (Case-insensitive checking)-- 响应头出现内容类型(不区分大小写的检查)
tests["content-type"]=postman.getResponseHeader("content-type")
13 JSON语法:
https://www.runoob.com/json/json-tutorial.html
1 JSON 语法规则
JSON 语法是 JavaScript 对象表示语法的子集。
数据在名称/值对中
数据由逗号分隔
大括号保存对象:{}
中括号保存数组:[]
2 JSON 值
JSON 值可以是:
数字(整数或浮点数)
字符串(在双引号中)
逻辑值(true 或 false)
数组(在中括号中)
对象(在大括号中)
3 JSON 对象中的数组:我们可以使用索引值来访问数组:
var obj={"name":"网站","num":3,"sites":[ "Google", "Runoob", "Taobao" ]}
x = myObj.sites[0];
4 JSON.parse():将字符串数据转换为 JavaScript 对象。
5 JSON.stringify():将 JavaScript 对象转换为字符串。
6 python:json.dumps(Python对象)---》将Python对象转换为json字符串对象
7 Python:json.loads(json字符串对象)----》将字符串对象变为python对象
14 mock server的用法:
Mock Server的使用范围(背景)
1 前后端分离项目
2 所测接口依赖第三方系统(还未具备)
3 所测接口依赖复杂或依赖的接口不稳定,并不作为主要验证对象
先创建mock server
选择mock server name(类似环境变量)
创建example为请求做例子:
每个request都可以有多个example:请求参数,请求体不停
每个example创建之后都可以修改
Mock server只会采用最后创建的example
也可直接在浏览器上验证:
https://875060cb-2f7d-4a69-92f4-c4e58e5dba61.mock.pstmn.io/api_tesst
==>{{url}/api_teest}