直接在Tests中写js代码断言结果,Test Result展示运行结果,简单方便。

示例脚本:

var jsonData = JSON.parse(responseBody);
var num = jsonData.data.length;
if(num > 0){
tests["检查是否返回sku数据"]=true;
} else{
tests["检查是否返回sku数据"]=false;
} //hot排序
var week2SalesVolume = new Array(num);
var flag = true; for(var i=0; i<num; i++){
week2SalesVolume[i]=jsonData.data[i].week2SalesVolume;
console.log(week2SalesVolume[i]);
} for(var i=0;i<week2SalesVolume.length-1;i++){
for(var j=i+1;j<week2SalesVolume.length;j++){
if(week2SalesVolume[i] < week2SalesVolume[j]){
flag = false;
break;
}
}
} if(flag){
tests["检查hot排序顺序"]=true;
}else{
tests["检查hot排序顺序"]=false;
} if(jsonData.policy=="A"){
tests["检查Query是否走指定版本"]=true;
}else{
tests["检查Query是否走指定版本"]=false;
}

示例response:

{
"succeed": true,
"code": 0,
"msg": "success",
"total": 19523,
"pageNo": 1,
"pageSize": 10,
"data": [
{
"week2SalesVolume": 1226.0
},
{
"week2SalesVolume": 1196.0
},
{
"week2SalesVolume": 1187.0
},
{
"week2SalesVolume": 1159.0
},
{
"week2SalesVolume": 1057.0
},
{
"week2SalesVolume": 1044.0
},
{
"week2SalesVolume": 1039.0
},
{
"week2SalesVolume": 979.0
},
{
"week2SalesVolume": 963.0
},
{
"week2SalesVolume": 913.0
}
],
"shopInfo": null,
"aggData": {},
"scrollId": null,
"policy": "A",
"planCode": null,
"bucketId": null,
"planId": null,
"versionId": null,
"cookie": null,
"point": null
}

其他常用脚本:

// 逻辑判断
tests["检查推广置顶sku不被取消"]=jsonData.data[0].goodsSn==="459492001";
tests["检查常规置顶sku不被置顶"]=jsonData.data[1].goodsSn != "231712410";
tests["检查sku实时算法分"] = jsonData.data[0]._scoreLog.details['ai score'] >= 1.0 && jsonData.data[0]._scoreLog.details['ai score']< 100; // 是否包含xx字段
tests["检查是否返回ai score字段"]=responseBody.has("ai score"); if(jsonData.policy=="Z"){
tests["检查是否走指定版本"]=true;
}else{
tests["检查是否走指定版本"]=false;
} // 常用脚本
# 响应时间必须少于200毫秒
tests["Response time is less than 200ms"] = responseTime < 200; // 状态码200
tests["Status code is 200"] = responseCode.code === 200; // 获取response返回内容
var rsb = responseBody; // 是字符串格式 // 设置环境变量 只能存储字符串,如果是对象的话则无法在下次运行时获取到内容
// 如需要存储JSON数据,可以用JSON.stringify(..)存储,再用JSON.parse(..)转化为对象使用
pm.environment.set("variable_key", "variable_value"); // 获取环境变量
var v = pm.environment.get("variable_key"); // 清除某个环境变量
pm.environment.unset("variable_key"); // 设置全局变量
pm.globals.set("variable_key", "variable_value");
// 获取全局变量和普通变量
var gb = pm.globals.get("variable_key");
var nm = pm.variables.get("variable_key");
// Javascript 获取变量类型
console.log( typeof pm.enviroment );

Postman Tests脚本的使用的更多相关文章

  1. Postman接口测试脚本编写规范

    Postman接口测试脚本编写规范 1.前言 2.名词解释 3.接口测试脚本规范 3.1接口测试脚本编写的规范 3.2 Postman使用规范 4.单个接口测试 5.整个流程的开发过程 1.前言 本规 ...

  2. postman(九):postman接口测试脚本集成到jenkins

    本篇的目的是实现使用jenkins远程执行postman接口测试脚本 准备工作:一台linux服务器(可以用虚拟机搭建一个),linux服务器上安装好node.js.newman,部署好jenkins ...

  3. Postman—测试脚本

    前言 对于Postman中的每个请求,我们都可以使用JavaScript语言来开发测试脚本.这也就好比单元测试.我们先看看Postman的相关界面: 编写测试脚本 Postman测试脚本本质上是在发送 ...

  4. Postman接口自动化--Postman Script脚本功能使用详解

    Postman Script 功能,支持原生的JS,所以可以使用JS解决很多接口自动化的一些问题,例如接口依赖.接口参数专递和接口断言等: 这里主要是针对Pre-Request Script 和 Te ...

  5. postman tests实例记录(还没看,一些常用的)

    这段时间准备测试api接口,postman这个工具很是方便,特别是里面的tests的javascript脚本. 记录一下测试接口常用的tests验证的实例. 1.设置环境变量 postman.setE ...

  6. postman tests常用方法

    postman常用方法集合: 1.设置环境变量 postman.setEnvironmentVariable("key", "value"); pm.envir ...

  7. postman Tests断言

    摘要:关于postman的断言方法很多,在网上随便搜寻下,能搜出一大推,什么牛鬼蛇神都有,让人眼花缭乱..甚至在应用时出现错误.Test断言都是根据js规则来写的,对于我这种不懂js语言的来说确实不友 ...

  8. postman 官方 test 脚本样例

    Test examples 样例来源: https://learning.getpostman.com/docs/postman/scripts/test_examples/ Test scripts ...

  9. Postman—命令执行脚本及生成报告

    前言 前面的应用中,都是在postman图形界面工具里面进行测试,但是有时候我们需要把测试脚本集成到CI平台,或者在非图形界面的系统环境下进行测试,那么我们该如果处理呢 通过newman来执行post ...

随机推荐

  1. sublime text 3基本参数设置及插件使用

    sublime text 3常用基本设置,包括插件,字体等一些配置.写个随笔,备忘. soda主题:特别喜欢: 插件:Color Highlighter输入颜色时,可以看到颜色. 在Color Hig ...

  2. octave - 用于数值计算的高级交互式语言

    SYNOPSIS 总览 octave [options] OPTIONS 选项 octave 全部命令行选项可以通过运行命令 octave --help 来查看. DESCRIPTION 描述 Oct ...

  3. VB.net删除节点,数据库,文件

    Private Sub mnuDel_Click()'删除节点Dim sKey As String'Dim sFile As StringDim oFS As FileSystemObjectDim ...

  4. 完整的node脚手架搭建服务

    使用脚手架来搭建node服务,使用到了express架构,不熟悉的可以看下express官方文档:http://www.expressjs.com.cn/ 使用express直接生成服务的文档结构目录 ...

  5. GUI学习之二十九—QInputDialog学习总结

    最后一种对话框是QInputDialog,,用来提供个输入的窗口. 一常用的静态方法 由于输入的类型不同,QInputDialog分为多种静态方法使用 #有步长调节器的整形数据,step为步长调节器的 ...

  6. vue全家桶是啥?

    Vue有著名的全家桶系列,包含了 1,调试插件:可以选择 Chrome 插件 vue Devtool(需要下载工具包).打开控制台选择 vue 面板.也可以选择 Vuex 选项.vuex(http:/ ...

  7. JSP页面与html页面在ie下显示的样式不一致的问题

    今天前端将样式与html给我文件我转化为jsp之后在我的电脑上使用IE11的IE9和其他浏览器都没有问题,但是在发给其他人检查的时候却发现在win7电脑的IE9上出现样式错乱的问题,前端调试无果的情况 ...

  8. mybatis insert update delete返回都是整型 0,1,增,删,改要提交事物

    mybatis insert update delete返回都是整型 0,1, 没有扔 增,删,改要提交事物

  9. 【ELK】ELK日志套件安装与使用

    ELK日志套件安装与使用   1.ELK介绍 ELK不是一款软件,而是elasticsearch+Logstash+kibana三款开源软件组合而成的日志收集处理套件,堪称神器.其中Logstash负 ...

  10. Solr Windows环境安装配置

    在本章中,我们将讨论如何在Windows环境中设置Solr.要在Windows系统上安装Solr,需要按照以下步骤 - 访问Apache Solr的主页,然后点击下载按钮或直接访问:http://lu ...