postman客户端下载地址:https://www.getpostman.com/apps

流程控制

流程控制简言之就是设置接口的执行顺序,流程控制只有在collection runner或Newman里才生效

如果需要实现多个接口的一次循环,只需在每个接口的Tests中编写脚本

postman.setNextRequest('下一个接口名');

操作如下图所示:

使用if进行判断来结束执行:

if(globals["我的地盘::创建新列表 - 禅道"])postman.setNextRequest("null");
tests["执行完毕!"] = responseCode.code ===200;

我的地盘::创建新列表 - 禅道为接口B中的返回值,在接口B中将其定义成一个全局变量。接口A通过判断全局变量是否存在进而判断接口B是否执行。如全局变量存在,将终止执行,否则执行接口B。

postman.setNextRequest("null");是一个终止程序作用

【注意】

1.如果不设终止条件,接口A执行完到接口B,接口B执行完又指向接口A,会构成死循环。该示例中if(globals["我的地盘::创建新列表 - 禅道"])为终止条件。

2.执行前需将用来做判断的全局变量删除,否则第一次执行完接口A后就将终止执行。

3.为了更清楚直观的查看运行结果,最好在每一个接口的Tests中增加一个断言,否则难以判断接口A执行的次数

调试

调试有三种方式:

1.使用Ctrl+Alt+c 可以打开Postman的控制台,可以查看请求和响应(只适用于客户端,不适用于Chrom 插件)

2.用console.log()打印,到控制台看

3.tests['这里拼出你想看的字符串'] = true在界面/报告看断言

使用Postman控制台查看,如下图所示:

使用console.log()打印输出内容操作如下图所示:

使用tests['这里拼出你想看的字符串'] = true,tests并不单单是指设置断言,也可以是普通的输出某些信息,如下图所示:

公共函数

常用的公共函数分为六种,分别是:

1).判断是否超时(assertNotTimeout):

var hasResponse=postman.getResponseHeader('Content-Type')?true:false; if(!hasResponse) tests['服务端在超时前没返回任何数据,请检查相关服务、网络或反向代理设置(以下跳过其他断言)']=false;

2).未超时,显示发出的请求参数(logParams):

if(hasResponse) tests[`[INFO] 请求参数(超时没返回时不解析):${JSON.stringify(request.data)}`]=true;

3).未超时,解析返回的JSON对象(getResponseJson):

try{if(hasResponse) var json=JSON.parse(responseBody);}catch(err){ tests['服务端没返回合法的JSON格式,请检查相关服务、网络或反向代理设置(以下跳过其他断言)']=false; tests[`[INFO] 返回:${responseBody}`]=true; console.error(err);}

4).返回元素的类型(assertType):

var assertType=(name,value,type)=>{let isType=(type==='array')? Array.isArray(value):typeof value===type; tests[`${name}为${type}(实际值:${value})`]=isType;};

5).返回元素是否与预期值一致(assertEqual):

var assertEqual=(name,actual,expected)=>{tests[`${name}等于${expected}(实际值:${actual})`]=actual===expected;};

6).返回元素是否与预期值不一致(assertNotEqual):

var assertNotEqual=(name,actual,expected)=>{tests[`${name}不等于${expected}(实际值:${actual})`]=actual!==expected;};

为了使用方便,所以将以上函数设置为全局变量,每行一对 key:value 的形式编辑设置成全局变量,如下图所示:

设置好之后,来使用以上函数,使用时的代码为:

eval(globals.assertNotTimeout);//判断是否超时eval(globals.logParams);//未超时,显示发出的请求参数eval(globals.getResponseJson);//未超时,解析返回的JSON对象eval(globals.assertType);//返回元素的类型eval(globals.assertEqual);//返回元素是否与预期值一致eval(globals.assertNotEqual);//返回元素是否与预期值不一致

各函数的具体用法,如下详解:

①第一个函数和第二个函数一起使用,先判断是否超时,若未超时,便显示发出的请求参数,操作如下图所示:

tests中的代码为:

eval(globals.assertNotTimeout);
eval(globals.logParams);

②第一个函数和第三个函数一起使用,先判断是否超时,若未超时,便解析返回的JSON对象,操作如下图所示:

tests中填入如下代码:

eval(globals.assertNotTimeout);
eval(globals.getResponseJson);tests[json.expires_in] = 7200;

注意:由于getResponseJson是解析返回的JSON对象,所以接口请求返回的定是JSON才能使用

③返回元素的类型(assertType),操作如下图所示:

tests中代码为:

eval(globals.assertType);//assertType=(name,value,type);//name为返回的元素key,value为该元素的值,type为该元素的类型assertType('姓名','boss','string');
assertType('昵称','一壶清酒','string');
assertType('数字',1,'number');

注意:此处需注意的是,数字类型并不是常说的int型,而是number,填入int会一直报错

返回元素类型的值中代码:var assertType=(name,value,type)=>{let isType=(type==='array')? Array.isArray(value):typeof value===type; tests[`${name}为${type}(实际值:${value})`]=isType;};

从返回元素类型的值中代码来看,该代码是一个三目运算符,重要点在于typeof中的value值,比如输入该代码:assertType('数字',1,'number');value为1,type为number,便会执行通过pass,若把type改为int,执行结果只会显示fail

进行如下操作就能轻而易举明了,如下所示:

tests中的代码为:

//解释typeoftests[typeof 'hello'] =true;//返回出来的是string,值的类型tests[typeof 1] =true;     //返回出来的是number

④返回元素是否与预期值一致(assertEqual),相等为true(pass),反之为false(fail),操作如下图所示:

tests中代码为:

eval(globals.assertNotTimeout);eval(globals.getResponseJson);
eval(globals.assertEqual);//assertEqual=(name,actual,expected);//name为返回的元素key,actual为返回的实际值,expected为预期值assertEqual('expires_in',json.expires_in,7200);
assertEqual('expires_in',json.expires_in,7100);

做简单的预期结果与实际结果判断也可如下操作:

eval(globals.assertEqual);//assertEqual=(name,actual,expected);//name为返回的元素key,actual为返回的实际值,expected为预期值//号码相同pass,不相同failassertEqual('电话号码',18867210313,18867210313);
assertEqual('电话号码',18867210310,18867210313);

⑤返回元素是否与预期值不一致(assertNotEqual),不相等为true(pass),反之为false(fail),操作如下图所示:

tests中代码如下

eval(globals.assertNotTimeout);
eval(globals.getResponseJson);
eval(globals.assertNotEqual);//assertNotEqual=(name,actual,expected);//name为返回的元素key,actual为返回的实际值,expected为预期值//号码不相等pass,相等failassertNotEqual('expires_in',json.expires_in,7100);
assertNotEqual('expires_in',json.expires_in,7200);

外部数据文件

外部数据文件是Collection Runner在HTTP requests 和script中可以导入CSV文件或是JSON文件,从数据文件(即CSV或JSON文件)中使用values,为了在Postman UI中去使用它们,你需要遵循和environment or global variables一样的语法。

操作步骤:

1.在你的Collection request中使用变量,以下的所有变量将会被数据文件中的相应的值替换

2.准备你所需要运行的数据文件(JSON/CSV)

CSV文件要在Collection Runner中工作,第一行必须是在request中要使用的变量名,每一行是一条用例,并表示一次迭代。

JSON文件,你需要确保你的文件有键/值对数组。数组中的每个元素是键值对的对象,代表了一次迭代。key是作为变量名,values是代替request里的值。

3.打开Collection Runner窗口以及选择合适的Collection或文件夹

4.选择“Choose files”,从文件选择区加载数据文件,如果加载成功,你可以预览Collection Runner中执行的数据量

5.设置迭代次数。每次迭代都将使用你的数据文件中的一行,如果迭代次数超过数据文件中的行数,将重复执行最后一行

6.运行Collection以及观察结果

举例为百度接口,设置好参数,如下图所示:

在左侧面板中选中该接口并运行,如下图所示:

配置参数,如下图所示:

csv格式文件先制作好,再在运行时添加进来,预览效果如为:

最终运行效果如下图所示:

原文地址:http://www.cnblogs.com/hong-fithing/p/7601859.html

.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

Postman高级应用——流程控制、调试、公共函数、外部数据文件相关推荐

  1. 14 MySQL--事务函数与流程控制

    一.事务 事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性. 一堆sql语句:要么同时执行成功,要么同时失败 # 事务的原子性场景: ...

  2. python调用什么函数实现对文件内容的读取_python读取文本文件数据

    本文要点刚要: (一)读文本文件格式的数据函数:read_csv,read_table 1.读不同分隔符的文本文件,用参数sep 2.读无字段名(表头)的文本文件 ,用参数names 3.为文本文件制 ...

  3. 《unix环境高级编程》笔记4——系统数据文件和信息

    文章目录 系统数据文件和信息 口令文件 获取口令文件 getwpuid getpwnam 阴影口令 组文件 附属组ID 查看附属组ID 其他文件 登录账户记录: 系统标识 uname gethostn ...

  4. MySql基础篇---004 其它数据库对象篇:视图,存储过程与函数,变量、流程控制与游标 ,触发器

    第14章_视图 讲师:尚硅谷-宋红康(江湖人称:康师傅) 官网:http://www.atguigu.com 1. 常见的数据库对象 对象 描述 表(TABLE) 表是存储数据的逻辑单元,以行和列的形 ...

  5. JavaScript【流程控制】【数组】【函数】【函数作用域】经典!!

    表达式和语句 表达式 一个表达式可以产生一个值,有可能是运算.函数调用.有可能是字面量.表达式可以放在任何需要值的地方. 语句 语句可以理解为一个行为,循环语句和判断语句就是典型的语句.一个程序有很多 ...

  6. python 基础(数据类型、运算符、流程控制、推导式、函数等...更新中)

    python基础 一.认识Python 1.python起源 Python 的创始人为吉多·范罗苏姆(Guido van Rossum),江湖人称"龟叔". 1991年,第一个Py ...

  7. MVEL快速入门—MVEL流程控制和高级功能(三)

    之前文章 MVEL快速入门-MVEL基础语法讲解(一) MVEL快速入门-MVEL属性和文字讲解(二) 流程控制 实际上MVEL的表达形式不仅仅局限于简单的表达式,他还支持流程控制.使我们能够执行高级 ...

  8. mysql 控制函数库_数据库开发——MySQL——函数与流程控制

    一.函数 1.介绍 1.1.数学函数 ROUND(x,y) 返回参数x的四舍五入的有y位小数的值 RAND() 返回0到1内的随机值,可以通过提供一个参数(种子)使RAND()随机数生成器生成一个指定 ...

  9. 11月8日学习内容整理:js的引入方式,变量数据类型,运算符,流程控制,函数...

    js是一门成熟的编程语言,专门用浏览器客户端执行的语言 一.js的引入方式 1.直接在body标签中使用script标签写js语言 2.通过script标签导入js文件,<script   sr ...

最新文章

  1. Java 开发Log4j 详细使用教程
  2. vs mysql 登录界面_vs登录界面连接数据库代码
  3. GitHub地图转误差坐标
  4. Base64编码及Android的应用
  5. oracle 取第三大的值,Oracle数据基础(三)
  6. 组合模式(Composition)
  7. 使用Xcode 4编译器设定Release/Debug教程
  8. 任务调度之Quartz2
  9. 十二、程序返回、数据类型表示、代码注释
  10. 【MyBatis笔记】02-MyBatis配置SQL打印
  11. redis增加auth
  12. C#强化系列文章七:序列化和反序列化
  13. Linux命令详解词典高频命令(2)
  14. Android WebView开发(三):WebView性能优化
  15. Java 标准 I/O 流编程一览笔录
  16. 文件上传 webshell 各类型 一句话木马 图片马 制作 教程
  17. python excel处理重复行并统计个数_python统计一个文本中重复行数的方法
  18. 银行从业如何备考,有什么刷题的APP?
  19. Excel的VBA使用
  20. 计算机应用基础 教材 黄洪艺,高教社产品信息检索系统

热门文章

  1. exchange2013 owa-outlook界面语言
  2. ARM再出手,软银攀登新高山
  3. Navicat Premium 怎么安装比较快
  4. iOS开发  plist字段列表,很全
  5. Avalonia跨平台入门第六篇之Grid动态分割
  6. 【.NET 遇上 GraphQL】 ChilliCream 平台介绍
  7. System.Drawing.Common workaround in .NET6
  8. 开源软件通识基础:第二周课程回顾与总结
  9. 解答网友提问:如何构建动态表达式实现高级查询服务
  10. Azure 上的网站如何识别不同国家和地区的用户