postman基础功能

一、变量设置

编写的API往往需要在多个环境下执行,而Postman 提供了两种类型的变量:环境变量和全局变量,从而很好的解决了这个问题。同时变量还常用于关联接口间的参数传递。

环境变量有效范围仅仅在于当前集合可用,全局变量对所有的集合都可用。

1.环境变量

1)手动创建

api可能需要在不同的环境中运行,所以api请求的服务器地址不能写死,希望是可以配置的,创建环境变量有多种方式

2)代码创建

在pre-request scripts中输入创建环境变量的命令,请求发起前后,在environment management中会新增该变量(也可在Tests中创建环境变量,不过该变量在请求发起后生效)

二、全局变量

与环境变量类似,也可以通过手工和代码创建

三、设置代理

应该时类似与fiddler的抓包吧

1.在postman中设置端口号、保存位置、筛选条件

2.设置本机代理服务器

postman高级应用

一、Scripts

Postman运行过程是基于强大的 Node.js,可以在请求发起前(Pre-request Script)和拿到请求返回后(Tests),通过编写JavaScript来实现请求间数据传递,请求参数动态生成等等。

Pre-request Script 和 Tests 可以在集合(Collections)、夹(Folder)、请求(Request)中设置。

1.脚本执行顺序

集合pre → 夹pre → 请求pre → Request → Response → 集合Tests → 夹Tests → 请求Tests

2.Tests

场景1:API间参数传递

如想要将登录接口响应的sessionid应用与所有请求的请求头中

response header

为了获得sessionid的值,并写入环境变量,我们可以在Tests 中加入如下脚本

 //获取响应头中“set-cookie”的value
var jsonData = postman.getResponseHeader("Set-Cookie");
console.log(jsonData);
//以;分隔字符串并取sessionid
cookie=jsonData.split(";")[0];
//设置环境变量
pm.environment.set("cookie", cookie);

场景2:response校验

responseHeaders[String]  {Object}:获取response的头部信息使用postman.getResponseHeader(‘xxx’)。

console.log(responseHeaders)
console.log(responseHeaders['Content-Type'])
console.log(postman.getResponseHeader('Content-Type'))
  • responseCookies {Array}:返回一个数组,可以通过postman.getResponseCookie(cookieName) 获取具体的cookie信息。
  • responseBody {string}:返回响应正文文本的字符串。可以用JSON.parse()转成数组。
  • responseTime {number}:返回响应时间,单位ms
  • responseCode[String] {Object}:返回的状态码,不带参数会返回4个属性。 常用的属性是 code 就是状态码。
console.log(responseCode)
console.log(responseCode['code'])
  • 设置环境变量
pm.environment.set("variable_key", "variable_value");
  • 获取环境变量
pm.environment.get("variable_key");
  • 清除环境变量
pm.environment.unset("variable_key");
  • 设置全局变量
pm.globals.set("variable_key", "variable_value");
  • 获取全局变量
pm.globals.get("variable_key");
  • 清除全局变量
pm.globals.unset("variable_key");
  • 获取一个变量:这个将从环境变量和全局变量中搜索变量,优先从环境变量中搜索
pm.variables.get("variable_key");
  • 发起一个请求:
pm.sendRequest("https://postman-echo.com/get", function (err, response) {
console.log(response.json());
});
  • 检查response body是否包含某个字符串
pm.test("Body matches string", function () {
pm.expect(pm.response.text()).to.include("string_you_want_to_search");
});
  • 检查response body是否等于某个字符串
pm.test("Body is correct", function () {
pm.response.to.have.body("response_body_string");
});
  • 检查JSON值
pm.test("Your test name", function () {
var jsonData = pm.response.json();
pm.expect(jsonData.value).to.eql(100);
});
  • 校验某结果类型是否存在:如下是说response header包含Content-Type
pm.test("Content-Type is present", function () {
pm.response.to.have.header("Content-Type");
});
  • 响应时间小于200毫秒
pm.test("Response time is less than 200ms", function () {
pm.expect(pm.response.responseTime).to.be.below(200);
});
  • 状态代码是200
pm.test("Status code is 200", function () {
pm.response.to.have.status(200);
});
  • 校验某对象是否包含某个字符串:例如下面校验response的body 包含 msg 属性
pm.test("Body is correct", function () {
pm.response.to.have.body("msg");
});
  • 校验结果在某范围中:如下校验请求状态码是201,202
pm.test("Successful POST request", function () {
pm.expect(pm.response.code).to.be.oneOf([201,202]);
});
  • 将XML主体转换为JSON对象:
var jsonObject = xml2Json(responseBody);

 3.pre-request scripts

场景3:自定义变量

场景4:接口依赖

例如我们调用LogOut的 API时,往往需要先执行LogIn的API,这时我们可以再pre-request script中编写个调用LogIn的API,先生成一条数据。

 //发送get请求
// pm.sendRequest("https://postman-echo.com/get", function (err, response) {
// console.log(response.json());
// }); //发送post请求
const regRequest={
url: "http://127.0.0.1:8081/api/accounts/login/",
method: "POST",
header:'Content-Type: application/json',//在header中声明使用类型
body: {
mode: 'raw',//使用raw原始模式
raw:JSON.stringify({"username":"admin","password":"admin"})//将json对象转化为文本发送
// mode: 'urlencoded',//使用raw原始模式
// urlencoded:[{key:"username",value:"admin"},{key:"password",value:"admin"}]
}
};
pm.sendRequest(regRequest, function (err, response) {
console.log(response.json());
});

跟Tests脚本类似,除了Response相关的不支持外,基本都支持。

二、Runner

 1.批量运行

  • 选取一个集合
  • 选择环境变量
  • 设置每个请求间隔时间(可不设置)
  • 点击 Run

运行界面可以查看每个请求的信息(如果Log Response设置为For no requests)则看不到任何的请求返回

2.数据驱动

数据驱动方式除了用于批量测试等价类的测试用例,更常用于通过接口批量造数据

下面我们就以批量测试等价类用例为例子讲解,批量造数据也是类似做法无非过程时常需要调用多个接口罢了。

假设有如下一个登录接口,我需要用不同的账号密码测试登录。

  • 那么第一步我们可以本地创建一个Json或者csv文件,设定username和password两个字段,并设置要运行的测试值:

    json/csv格式

         

  • 设置请求参数,通过{{变量名}}获取文件中的参数值

  • Runer运行,设定Data,选择你的csv或json文件后会自动帮你统计出 Iterrations,并可以通过Preview 预览数据源

  • 点击run,可以结果页面看到我们一个api发起了3次请求,并每次请求都从数据源拿去一条对应的数据

【postman】postman使用教程的更多相关文章

  1. PostMan入门使用教程

    最近需要测试产品中的REST API,无意中发现了PostMan这个chrome插件,把玩了一下,发现postman秉承了一贯以来google工具强大,易用的特质.独乐乐不如众乐乐,特此共享出来给大伙 ...

  2. Postman+Postman interceptor的安装和使用-解决把chrome浏览器登录状态同步到postman进行有依赖的接口测试 Postman 使用方法详解

    Postman+Postman interceptor的安装和使用-解决把chrome浏览器登录状态同步到postman进行有依赖的接口测试   问题引入:做接口测试时,有依赖关系的接口往往不好测试( ...

  3. Postman 官网教程,重点内容,翻译笔记,

    json格式的提交数据需要添加:Content-Type :application/x-www-form-urlencoded,否则会导致请求失败 1. 创建 + 测试: 创建和发送任何的HTTP请求 ...

  4. postman安装使用教程---图文讲解

    一.安装postman 1,安装包安装 官网下载地址:https://www.getpostman.com 选择好对应的版本下载,下载完后直接安装 2,插件包安装 可以在谷歌的应用商店里面找到,或者在 ...

  5. 接口测试工具Postman接口测试图文教程

    Postman接口测试工具使用 一.前言     在前后端分离开发时,后端工作人员完成系统接口开发后,需要与前端人员对接,测试调试接口,验证接口的正确性可用性.而这要求前端开发进度和后端进度保持基本一 ...

  6. postman 简单使用教程

    Postman 安装   Postman 接口测试(Collection)   Postman 接口测试(测试用例)Postman 接口测试(变量与参数化)Postman 接口测试(非 UI 运行模式 ...

  7. 【Python+postman接口自动化测试】(7)Postman 的使用教程

    Postman v6的使用 Postman: 简单方便的接口调试工具,便于分享和协作.具有接口调试,接口集管理,环境配置,参数化,断言,批量执行,录制接口,Mock Server, 接口文档,接口监控 ...

  8. postman插件安装教程

    第一步: 第二步: 第三步: 这样就可以了. 插件下载链接: http://pan.baidu.com/s/1eRVLMpk 密码: 49vb

  9. Chrome+postman+postman interceptor调试

    本文使用chrome+postman4.8.3+postman interceptor0.2.23调试使用cookie的请求. postman4.8.3下载地址:https://pan.baidu.c ...

  10. [Postman]Postman导航(3)

    Postman提供了一个多窗口和多标签界面,供您使用API​​. 此界面设计为您提供尽可能多的API空间. 侧边栏 邮差侧边栏可让您查找和管理请求和集合.侧边栏有两个主要选项卡:  历史记录  和   ...

随机推荐

  1. 【Mac】解决外接显示器时无法用键盘调节音量

    背景:mac book pro  外接一台显示器 可以有音量,音量较小, 外接两台显示器时候直接显示如下了 解决办法: 操作步骤: 从 GitHub 下载 SoundFlower 扩展,并安装.(首次 ...

  2. 123457123457#0#-----com.tym.PuzzleGame28--前拼后广--日常pt-tym

    com.tym.PuzzleGame28--前拼后广--日常pt-tym

  3. Python - Django - ORM 自定义 char 类型字段

    用 CharField 定义的字段在数据库中存放为 verchar 类型 自定义 char 类型字段需要下面的代码: class FixedCharField(models.Field): " ...

  4. LeetCode_278. First Bad Version

    278. First Bad Version Easy You are a product manager and currently leading a team to develop a new ...

  5. C-LODOP回调多个返回值On_Return_Remain

    c-lodop默认一次只能回调一个值,回调后会销毁,如果想回调多个值,可加该语句:LODOP.On_Return_Remain=true;之前有博文:lodop和c-lodop通过打印状态和任务不在队 ...

  6. Consul 快速入门 - Kong最佳实践

    Consul是什么 Consul是一个服务网格(微服务间的 TCP/IP,负责服务之间的网络调用.限流.熔断和监控)解决方案,它是一个一个分布式的,高度可用的系统,而且开发使用都很简便.它提供了一个功 ...

  7. Appium移动自动化测试-----(六)1.appium-desktop下载安装

    Appium 移动测试中有个很重新的组件 Appium-Server,它主要用来监听我们的移动设备(真机或模拟器),然将不同编程语言编写的 appium 测试脚本进行解析,然后,驱动移动设备来运行测试 ...

  8. 一个unsigned int 数的二进制表示中有多少个1

    这是一道面试题可以用以下的一些方案.第一种是很容易想到的采用循环的方式并且与1进行位与运算,具体代码如下.  1unsigned int GetBitNumOfOne_ByLoop1(unsigned ...

  9. 《ucore lab2》实验报告

    资源 ucore在线实验指导书 我的ucore实验代码 练习1:实现 first-fit 连续物理内存分配算法 题目 在实现first fit 内存分配算法的回收函数时,要考虑地址连续的空闲块之间的合 ...

  10. React项目使用React-Router

    ⒈初始化React项目(略) 请参考 初始化一个React项目(TypeScript环境) ⒉集成React-Router 在React世界里,公认最好用的路由是React-Router.那我们直接来 ...