作者:夕夕石(碩爺)
QQ:2470798103
一吮龄、全局變量、環(huán)境變量咆疗、集合變量的配置
Postman中有三種變量:全局變量(Globals)漓帚、環(huán)境變量(environment)、集合變量/項(xiàng)目變量)
(1)集合變量/Collection變量/項(xiàng)目變量(variables)
(對(duì)該集合及子文件夾下所有請(qǐng)求生效), 在新建/編輯 Collection -> Variables 中可以添加
(2)全局變量(Globals)
(對(duì)所有請(qǐng)求生效), 在 環(huán)境管理 -> Globals中添加
(3)環(huán)境變量(environment)
可以先看下面的:
- VARIAVLE:變量名
- INITIAL VALUE:共享初始值, 用于團(tuán)隊(duì)共享時(shí)供別人使用的默認(rèn)值
- CURRENT VALUE:當(dāng)前值, 自己當(dāng)前使用的變量值(一般我們只用設(shè)置這個(gè)值即可)
- Perisit All:保持所有, 將所有的初始值替換為所有的CURRENT VALUE
- Reset All:重置所有, 將當(dāng)前所有的CURRENT VALUE重置為與當(dāng)前初始值一樣
(4)環(huán)境
二午磁、全局變量尝抖、環(huán)境變量毡们、集合變量的使用
(1)非腳本情況,使用變量
請(qǐng)求url昧辽,params 參數(shù)或 body表格或 JSON/XML 文本中通過(guò) {{變量名}} 使用
(2)腳本中使用環(huán)境變量
在 Pre-request Script 和 Tests中使用
- 設(shè)置
設(shè)置普通變量
pm.environment.set("variable_key", "variable_value");
設(shè)置嵌套對(duì)象類(lèi)型的變量
var array = [1, 2, 3, 4];
pm.environment.set("array", JSON.stringify(array, null, 2));
var obj = { a: [1, 2, 3, 4], b: { c: 'val' } };
pm.environment.set("obj", JSON.stringify(obj));
- 獲取
普通變量
pm.environment.get("variable_key");
字符串化對(duì)象的變量
// These statements should be wrapped in a try-catch block if the data is coming from an unknown source.
var array = JSON.parse(pm.environment.get("array"));
var obj = JSON.parse(pm.environment.get("obj"));
- 清除
pm.environment.unset("variable_key");
(3)腳本中使用全局變量
在 Pre-request Script 和 Tests中使用
- 設(shè)置
pm.globals.set("variable_key", "variable_value");
- 獲取
pm.globals.get("variable_key");
- 清除
pm.globals.unset("variable_key");
(4)腳本中使用變量
在 Pre-request Script 和 Tests中使用
- 獲取
此函數(shù)在環(huán)境環(huán)境漏隐、集合變量、全局變量中搜索變量奴迅。
pm.variables.get("variable_key");
三青责、全局變量、環(huán)境變量取具、集合變量的優(yōu)先級(jí)
變量?jī)?yōu)先級(jí)
當(dāng)變量重名時(shí), 優(yōu)先級(jí)為:
環(huán)境變量 > Collection變量 > 全局變量(Globals)
四脖隶、常用的全局變量
前提:將如下內(nèi)容復(fù)制到一個(gè)json文件中,然后導(dǎo)入postman暇检。
不想導(dǎo)入或者導(dǎo)入失敗的話(huà)产阱,也可以將下面文件中的key、value各自粘貼到你的全局變量里面
{
"id": "ed7f409a-c35b-441f-8414-fdc3124c36c5",
"values": [
{
"key": "assertNotTimeout",
"value": "var hasResponse=postman.getResponseHeader('Content-Type')?true:false; if(!hasResponse) tests['服務(wù)端在超時(shí)前沒(méi)返回任何數(shù)據(jù)块仆,請(qǐng)檢查相關(guān)服務(wù)构蹬、網(wǎng)絡(luò)或反向代理設(shè)置(以下跳過(guò)其他斷言)']=false;",
"enabled": true
},
{
"key": "logParams",
"value": "if(hasResponse) tests[`[INFO] 請(qǐng)求參數(shù)(超時(shí)沒(méi)返回時(shí)不解析):${JSON.stringify(request.data)}`]=true;",
"enabled": true
},
{
"key": "getResponseJson",
"value": "try{if(hasResponse) var json=JSON.parse(responseBody);}catch(err){ tests['服務(wù)端沒(méi)返回合法的JSON格式,請(qǐng)檢查相關(guān)服務(wù)悔据、網(wǎng)絡(luò)或反向代理設(shè)置(以下跳過(guò)其他斷言)']=false; tests[`[INFO] 返回:${responseBody}`]=true; console.error(err);}",
"enabled": true
},
{
"key": "assertType",
"value": "var assertType=(name,value,type)=>{let isType=(type==='array')? Array.isArray(value):typeof value===type; tests[`${name} 為 ${type}類(lèi)型(實(shí)際值:${value})`]=isType;};",
"enabled": true
},
{
"key": "assertEqual",
"value": "var assertEqual=(name,actual,expected)=>{tests[`${name} 等于 ${expected}(實(shí)際值:${actual})`]=actual===expected;};",
"enabled": true
},
{
"key": "assertNotEqual",
"value": "var assertNotEqual=(name,actual,expected)=>{tests[`${name} 不等于 ${expected}(實(shí)際值:${actual})`]=actual!==expected;};",
"enabled": true
}
],
"name": "My Workspace Globals",
"_postman_variable_scope": "globals",
"_postman_exported_at": "2019-06-17T11:28:20.839Z",
"_postman_exported_using": "Postman/7.2.0"
}
作用:在腳本中寫(xiě)入斷言庄敛,運(yùn)行單條用例或runner多條后,在pass科汗、fail后顯示詳細(xì)信息藻烤,如下:
(1)顯示post請(qǐng)求的請(qǐng)求參數(shù),并生成一條斷言
eval(globals.assertNotTimeout);
eval(globals.logParams);//如果上面沒(méi)超時(shí)头滔,返回post請(qǐng)求的請(qǐng)求參數(shù)
(2)顯示響應(yīng)的字段值怖亭,并生成一條斷言
eval(globals.assertNotTimeout);
eval(globals.getResponseJson);
tests["success字段的值:" + json.success] = true;
tests["info字段的name字段的值:" + json.info.name] = true;
(3)assertType,判斷類(lèi)型坤检,并生成一條斷言
//判斷類(lèi)型:"string"兴猩、"number"
eval(globals.assertType);
assertType("username ",pm.response.json().username,"string");
assertType("username ",pm.response.json().code,"number");
(4)assertEqual,判斷是否相等早歇,并生成一條斷言
eval(globals.assertEqual);
//assertEqual=(name,actual,expected);
//name為返回的元素key倾芝,actual為返回的實(shí)際值,expected為預(yù)期值
assertEqual('code ', pm.response.json().code, 2);
assertEqual('username ', pm.response.json().username, "ZhangYiMing");
(5)assertNotEqual缺前,判斷是否不等蛀醉,并生成一條斷言
eval(globals.assertNotEqual);
//assertNotEqual=(name,actual,expected);
//name為返回的元素key,actual為返回的實(shí)際值衅码,expected為預(yù)期值
assertNotEqual('code ',pm.response.json().code, 23);
assertNotEqual('username ',pm.response.json().username , "期望值")
五拯刁、參數(shù)化
1、參數(shù)化概念
入?yún)⒅惺哦危粚?xiě)實(shí)際的值垛玻,而是寫(xiě)成 {{變量名}} 的形式割捅,就是參數(shù)化。
2帚桩、單接口運(yùn)行
單接口運(yùn)行時(shí)亿驾,這些變量都取自你的環(huán)境變量、集合變量账嚎、全局變量莫瞬。
3、集合運(yùn)行
選擇你運(yùn)行的集合名稱(chēng)郭蕉、環(huán)境疼邀,直接 run 即可
六、數(shù)據(jù)驅(qū)動(dòng)
1召锈、編輯數(shù)據(jù)驅(qū)動(dòng)文件
(1)新建一個(gè) txt 文件旁振;
(2)第一行寫(xiě)參數(shù)化的變量名稱(chēng),用英文逗號(hào)隔開(kāi)涨岁;
(3)從第二行開(kāi)始拐袜,每一行是一組數(shù)據(jù);
2梢薪、run前的設(shè)置
選擇集合名稱(chēng)蹬铺、環(huán)境、數(shù)據(jù)驅(qū)動(dòng)文件沮尿、文件類(lèi)型丛塌、迭代次數(shù)。之后Run起來(lái)畜疾。
3、預(yù)覽數(shù)據(jù)驅(qū)動(dòng)文件
在選定完數(shù)據(jù)驅(qū)動(dòng)文件后印衔,可以點(diǎn)擊 Preview 預(yù)覽文件內(nèi)容