Postman的强大之处在于其容许在对某一个request访问的以前和以后分别运行自定义的一段Javascript脚本,这样直接就完成了一个
chain request
的效果,能够将数条request连结成一个流程完成一体化测试。这在不少的API操做中都是极其有用的,因此这里有必要总结一些经常使用语句。
参考Postman官方:Intro to scriptsjavascript
pre-request
脚本,是在对API进行请求以前的脚本,通常用于动态生成参数、JSON数据包、连接地址等。test
脚本,其实更应该叫post-request
,实在完成API访问并获得其response回应以后运行的脚本,通常用于获取response的内容,用于以后对于别的资源的请求,如获取页面标题和内容等。须要注意,pre-request
脚本,在里面直接写代码就能够了,可是test
脚本须要在某个指定的函数pm.test(...)
中执行才会被识别,且做为test
脚本运行。以下图:pm.test()
中第一个参数是测试描述(会在测试结果栏显示,应和其它测试描述作以区分),第二个参数是一个函数,具体执行代码都在这个函数中运行。
另外,pm
对象是Postman的主要对象,全部的内置函数,数据调用等,都须要经过它来实现。html
通常会在脚本编写栏的右边都会有经常使用语句片断,点击如下就会出来代码,可是一开始不太了解的话点出来其实也看不懂。以下图:java
官方文档解释的各类函数调用连接在这里:Postman Sandboxchrome
如下是我本身总结的经常使用代码片断:json
// 获取response返回内容 var rsb = responseBody; // 是字符串格式 // 获取环境变量 var v = pm.environment.get("变量名称"); // 设置环境变量 只能存储字符串,若是是对象的话则没法在下次运行时获取到内容 // 如须要存储JSON数据,能够用JSON.stringify(..)存储,再用JSON.parse(..)转化为对象使用 pm.environment.set("变量名称", 变量内容); // 清除某个环境变量 pm.environment.unset("环境变量名"); // 获取全局变量和普通变量 var gb = pm.globals.get("全局变量名"); var nm = pm.variables.get("普通变量名"); // Javascript 获取变量类型 console.log( typeof pm.enviroment );
Pre-request script
是在request以前准备request信息用的脚本。api
参考Postman官方:Pre-request scripts浏览器
经常使用的准备工做有:app
经常使用的语句以下:less
// 获取环境变量 var v = pm.environment.get("变量名称"); // 设置环境变量 只能存储字符串,若是是对象的话则没法在下次运行时获取到内容 // 如须要存储JSON数据,能够用JSON.stringify(..)存储,再用JSON.parse(..)转化为对象使用 pm.environment.set("变量名称", 变量内容);
测试脚本是在request以后,对Response的返回值进行下一步处理的脚本。函数
参考Postman官方:Test scripts
参考Postman官方:Test examples
经常使用的处理有:
经常使用的语句以下:
// 获取response headers中某一个值 ctype = postman.getResponseHeader("Content-Type"); // 获取response body的所有内容 text = pm.response.text(); // 获取response返回的所有JSON json_data = pm.response.json(); // 获取json中某一个值,好比name的值: myName = json_data.name;
除了上面的具体功能代码外,常常还须要返回一个结果,告诉Postman这个测试结果是Pass仍是Fail,默认是pass。
这里返回值就不是简单的return语句能够,必需要经过Postman自带的对象或方法才能够,通常是经过pm.expect()
或tests[]
这两个地方返回测试结果。
完整的测试示范:
// 测试response的状态是不是200成功: pm.test("Status code is 200", function () { pm.response.to.have.status(200); });
这些方法名看起来都很容易理解,通常都会叫pm.expect()
或.to.be()
或.to.have()
这样的,字面意思就是期待什么或要求它必须是什么或必须有什么,才能经过测试。
另外,一样的测试结果,实际上还有更简单的写法,即不经过pm
对象,而是内置tests
对象。
经常使用操做以下:
# 反应时间必须少于200毫秒 tests["Response time is less than 200ms"] = responseTime < 200; # 判断反应代号是否等于某一个指定的代号 tests["Status code name has string"] = responseCode.name.has("Created");
看这个用法,猜想tests
是一个JSON格式的对象,tests[...]
括号内的字符串是测试的描述, =
后面是判断语句,而后将True或False赋予为tests[..]
的值,而后postman轮训全部tests
对象里的参数,并返回pass与否的结果。
这里是官方总结的经常使用测试脚本方法:Test examples
如下是我总结的经常使用的返回测试结果的内置函数:
# “期待”返回结果必须包含某一段内容 pm.expect(从response里获取的字符串).to.include("必须包含的内容"); # 返回body值必须彻底等于某一段内容 pm.response.to.have.body("必须等于的内容"); # 反应时间必须少于200毫秒 pm.expect(pm.response.responseTime).to.be.below(200); # 必须返回某一个状态 如"Created" pm.response.to.have.status("状态名");
若是要看已经设置的Enviroment变量的话,能够点开右上方小眼睛看到,以下图,我设置了3个环境变量:
调试时要打印的话,通常都是用console.log(...)
,这样就能在console中看到:
位置在左下角,以下图:
Postman的Sandbox是Postman内部默认引入的第三方JS库。
参考:Postman Sandbox 官方脚本可引用库说明
参考:Postman Sandbox API 官方引用的脚本库详解
Sandbox引用的第三方库有:
生成MD5字符串:
var hashed = CryptoJS.MD5("待加密的字符串");
文件转base64字符串:
s = 'Hello'; // 先转化成UTF-8编码的字符串 utf8 = CryptoJS.enc.Utf8.parse( s ); // 用CryptoJS第三方库(Postman已经内置了)进行编码 b64 = CryptoJS.enc.Base64.stringify(utf8) console.log(b64); // aGVsbG8=
不一样于Sandbox,这是Postman内部较高级的SDK,能够引用一些方便的方法。
参考官方网址:Tutorial: Postman SDK Concepts
URL转换成JSON格式,并获取指定的参数值:
var sdk = require('postman-collection'); query = ( new sdk.Url(callback) ).toJSON().query; for (var i in query) { console.log(query[i].key +": "+ query[i].value); }