postman變量+參數(shù)化+數(shù)據(jù)驅(qū)動


作者:夕夕石(碩爺)

QQ:2470798103


一、全局變量、環(huán)境變量、集合變量的配置

Postman中有三種變量:全局變量(Globals)、環(huán)境變量(environment)、集合變量/項目變量)

(1)集合變量/Collection變量/項目變量(variables)

(對該集合及子文件夾下所有請求生效), 在新建/編輯 Collection -> Variables 中可以添加

image
image

(2)全局變量(Globals)

(對所有請求生效), 在 環(huán)境管理 -> Globals中添加

image
image

(3)環(huán)境變量(environment)

可以先看下面的:

image
image
  • VARIAVLE:變量名
  • INITIAL VALUE:共享初始值, 用于團(tuán)隊共享時供別人使用的默認(rèn)值
  • CURRENT VALUE:當(dāng)前值, 自己當(dāng)前使用的變量值(一般我們只用設(shè)置這個值即可)
  • Perisit All:保持所有, 將所有的初始值替換為所有的CURRENT VALUE
  • Reset All:重置所有, 將當(dāng)前所有的CURRENT VALUE重置為與當(dāng)前初始值一樣

(4)環(huán)境

image

二、全局變量、環(huán)境變量、集合變量的使用

(1)非腳本情況,使用變量

請求url,params 參數(shù)或 body表格或 JSON/XML 文本中通過 {{變量名}} 使用

image

(2)腳本中使用環(huán)境變量

在 Pre-request Script 和 Tests中使用

  • 設(shè)置

設(shè)置普通變量

pm.environment.set("variable_key", "variable_value");

設(shè)置嵌套對象類型的變量

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");

字符串化對象的變量

// 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)先級

變量優(yōu)先級

當(dāng)變量重名時, 優(yōu)先級為:
環(huán)境變量 > Collection變量 > 全局變量(Globals)

四、常用的全局變量

前提:將如下內(nèi)容復(fù)制到一個json文件中,然后導(dǎo)入postman。

不想導(dǎo)入或者導(dǎo)入失敗的話,也可以將下面文件中的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ù)據(jù),請檢查相關(guān)服務(wù)、網(wǎng)絡(luò)或反向代理設(shè)置(以下跳過其他斷言)']=false;",
            "enabled": true
        },
        {
            "key": "logParams",
            "value": "if(hasResponse) tests[`[INFO] 請求參數(shù)(超時沒返回時不解析):${JSON.stringify(request.data)}`]=true;",
            "enabled": true
        },
        {
            "key": "getResponseJson",
            "value": "try{if(hasResponse) var json=JSON.parse(responseBody);}catch(err){ tests['服務(wù)端沒返回合法的JSON格式,請檢查相關(guān)服務(wù)、網(wǎng)絡(luò)或反向代理設(shè)置(以下跳過其他斷言)']=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}類型(實(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"
}

作用:在腳本中寫入斷言,運(yùn)行單條用例或runner多條后,在pass、fail后顯示詳細(xì)信息,如下:

(1)顯示post請求的請求參數(shù),并生成一條斷言

eval(globals.assertNotTimeout); 
eval(globals.logParams);//如果上面沒超時,返回post請求的請求參數(shù)

(2)顯示響應(yīng)的字段值,并生成一條斷言

eval(globals.assertNotTimeout); 
eval(globals.getResponseJson);
tests["success字段的值:" + json.success] = true;
tests["info字段的name字段的值:" + json.info.name] = true;

(3)assertType,判斷類型,并生成一條斷言

//判斷類型:"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)⒅?,不寫?shí)際的值,而是寫成 {{變量名}} 的形式,就是參數(shù)化。

image

2、單接口運(yùn)行

單接口運(yùn)行時,這些變量都取自你的環(huán)境變量、集合變量、全局變量。

3、集合運(yùn)行

選擇你運(yùn)行的集合名稱、環(huán)境,直接 run 即可

image

六、數(shù)據(jù)驅(qū)動

1、編輯數(shù)據(jù)驅(qū)動文件

  • (1)新建一個 txt 文件;

  • (2)第一行寫參數(shù)化的變量名稱,用英文逗號隔開;

  • (3)從第二行開始,每一行是一組數(shù)據(jù);

2、run前的設(shè)置

選擇集合名稱、環(huán)境、數(shù)據(jù)驅(qū)動文件、文件類型、迭代次數(shù)。之后Run起來。

image

3、預(yù)覽數(shù)據(jù)驅(qū)動文件

在選定完數(shù)據(jù)驅(qū)動文件后,可以點(diǎn)擊 Preview 預(yù)覽文件內(nèi)容

image
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容