postman使用

2020-03-19  本文已影响0人  何以笙箫默_4eb8

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}

上一篇 下一篇

猜你喜欢

热点阅读