Postman使用小教程--基础入门篇
文章目錄
- 1 Postman介紹
- 2 postman基礎(chǔ)功能介紹
- 2.1 postman基礎(chǔ)頁(yè)面
- 2.2 postman基礎(chǔ)頁(yè)面介紹
- 2.2 接口測(cè)試流程和原理
- 2.3 請(qǐng)求區(qū)域介紹
- 3 導(dǎo)出和導(dǎo)入接口集
- 3.1 導(dǎo)出
- 3.2 導(dǎo)入
- 4 設(shè)置環(huán)境變量
- 4.1 環(huán)境變量?jī)?yōu)先級(jí)
- 4.2 新建環(huán)境變量
- 4.3 將返回值的某個(gè)數(shù)據(jù)設(shè)置為環(huán)境變量
- 4.4 將其他的常用tests方法
- 5 使用postman進(jìn)行接口自動(dòng)化測(cè)試
- 6 附錄
1 Postman介紹
Postman是一款功能強(qiáng)大的網(wǎng)頁(yè)調(diào)試與發(fā)送網(wǎng)頁(yè)HTTP請(qǐng)求的Chrome插件。簡(jiǎn)單來(lái)說(shuō),四個(gè)詞,簡(jiǎn)單實(shí)用大方美觀!
Postman官網(wǎng)下載地址:https://www.postman.com/downloads/
2 postman基礎(chǔ)功能介紹
2.1 postman基礎(chǔ)頁(yè)面
2.2 postman基礎(chǔ)頁(yè)面介紹
Collection在postman里面相當(dāng)于一個(gè)文件夾,可以把同一個(gè)項(xiàng)目的請(qǐng)求放在一個(gè)Collection里方便管理和分享,Collection里面也可以再建文件夾。
這里我們做一個(gè)普通接口的簡(jiǎn)單的示例:
Step1:新建一個(gè)文件夾
Step2:文件夾創(chuàng)建完畢,新建一個(gè)請(qǐng)求
Step3:輸入請(qǐng)求URL和請(qǐng)求參數(shù),點(diǎn)擊“Send”
在此給大家推薦幾個(gè)數(shù)據(jù)接口網(wǎng)站,注冊(cè)就有免費(fèi)調(diào)用機(jī)會(huì):
點(diǎn)擊進(jìn)入APILINK
點(diǎn)擊進(jìn)入聚合數(shù)據(jù)中心
控制臺(tái)-天氣API
2.2 接口測(cè)試流程和原理
接收包理解:
2.3 請(qǐng)求區(qū)域介紹
請(qǐng)求部分介紹:
請(qǐng)求區(qū)域介紹:
1 Authorization:身份驗(yàn)證,主要用來(lái)填寫(xiě)用戶(hù)名密碼,以及一些驗(yàn)簽字段,postman有一個(gè)helpers可以幫助我們簡(jiǎn)化一些重復(fù)和復(fù)雜的任務(wù)。當(dāng)前的一套helpers可以幫助你解決一些authentication protocols的問(wèn)題。;
2 Headers:請(qǐng)求的頭部信息
3 Body:post請(qǐng)求時(shí)必須要帶的參數(shù),里面放一些key-value鍵值對(duì)
4 Pre-requerst Script:可以讓你在 請(qǐng)求之前自定義請(qǐng)求數(shù)據(jù),這個(gè)運(yùn)行在請(qǐng)求之前,語(yǔ)法使用JavaScript語(yǔ)句。
5 tests:tests標(biāo)簽功能比較強(qiáng)大,通常用來(lái)寫(xiě)測(cè)試,它是運(yùn)行在請(qǐng)求之后。支持JavaScript語(yǔ)法。postman每次執(zhí)行request的時(shí)候,會(huì)執(zhí)行tests。測(cè)試結(jié)果會(huì)在tests的tab上面顯示一個(gè)通過(guò)的數(shù)量以及對(duì)錯(cuò)情況。這個(gè)后面會(huì)進(jìn)行詳解,它也可以用來(lái)設(shè)計(jì)用例,比如要測(cè)試返回結(jié)果是否含有某一字符串
6 form-data:,它將表單數(shù)據(jù)處理為一條消息,以標(biāo)簽為單元,用分隔符分開(kāi)。既可以單獨(dú)上傳鍵值對(duì),也可以直接上傳文件(當(dāng)上傳字段是文件時(shí),會(huì)有Content-Type來(lái)說(shuō)明文件類(lèi)型,但該文件不會(huì)作為歷史保存,只能在每次需要發(fā)送請(qǐng)求的時(shí)候,重新添加文件。);post請(qǐng)求里較常用的一種
7 x-www-form-urlencoded:對(duì)應(yīng)信息頭-application/x-www-from-urlencoded,會(huì)將表單內(nèi)的數(shù)據(jù)轉(zhuǎn)換為鍵值對(duì);
8 raw:可以上傳任意類(lèi)型的文本,比如text、json、xml等,所有填寫(xiě)的text都會(huì)隨著請(qǐng)求發(fā)送;
9 binary:對(duì)應(yīng)信息頭-Content-Type:application/octet-stream,只能上傳二進(jìn)制文件,且沒(méi)有鍵值對(duì),一次只能上傳一個(gè)文件, 也不能保存歷史,每次選擇文件,提交;
3 導(dǎo)出和導(dǎo)入接口集
postman支持非常方便的導(dǎo)入和導(dǎo)出接口集,繼續(xù)操作如下:
3.1 導(dǎo)出
3.2 導(dǎo)入
0 error,0 wainning,如此即簡(jiǎn)單的導(dǎo)入導(dǎo)出collection集合
4 設(shè)置環(huán)境變量
4.1 環(huán)境變量?jī)?yōu)先級(jí)
| Enviroment | 環(huán)境變量 |
| Loca | 局部 |
| Data | 數(shù)據(jù) |
優(yōu)先級(jí)從高到底: Data ---- > Local ---- > Enviroment ---- > Global
postman支持很方便的設(shè)置環(huán)境變量以及全局變量,并可以一鍵切換不同環(huán)境
可以一鍵切換環(huán)境,選擇No Environment則不使用環(huán)境變量,僅適用全局變量
可以查看當(dāng)前環(huán)境中的變量和全局變量(Globals)的值
進(jìn)入設(shè)置頁(yè)面
4.2 新建環(huán)境變量
新建一套環(huán)境變量名為test
創(chuàng)建環(huán)境變量意義:能夠很方便的調(diào)取我們所需的數(shù)據(jù)
4.3 將返回值的某個(gè)數(shù)據(jù)設(shè)置為環(huán)境變量
應(yīng)用場(chǎng)景:在某些時(shí)候,我們需要獲取到一個(gè)變量,并保存下來(lái),因?yàn)樵诤竺嫖覀儠?huì)使用到。比如token信息;
這時(shí)候就需要用到tests區(qū)域了,使用其強(qiáng)大的js語(yǔ)法
下面是一個(gè)簡(jiǎn)單的將返回值的某個(gè)數(shù)據(jù)設(shè)置為環(huán)境變量或者全局變量的介紹:
//定義一個(gè)xxx,獲取body中返回的所有參數(shù),并轉(zhuǎn)化為JSON格式var xxx = JSON.parse(responseBody);//檢查json中某個(gè)數(shù)組元素的個(gè)數(shù)(這里檢測(cè)programs的長(zhǎng)度) tests["program's lenght"] = data.programs.length === 5;//將返回中的值設(shè)置為一個(gè)環(huán)境變量pm.environment.set("key",xxx.data.value);或者:postman.setEnvironmentVariable("key", "value");//將返回中的值設(shè)置為一個(gè)全局變量, pm.globals.set("key",xxx.data.value); 或者postman.setGlobalVariable("key", "value");//注意:Global后面不能加S,value值一定要指定到某個(gè)具體節(jié)點(diǎn)4.4 將其他的常用tests方法
在postman里,內(nèi)置了一些常用的方法,可以很方便的調(diào)用:
下面是一些常用的tests方法:
1./*測(cè)試response Headers中的某個(gè)元素是否存在 */ tests["元素Content-Type是否存在"] = postman.getResponseHeader("Content-Type"); //getResponseHeader()方法會(huì)返回header的值;2./*定義一個(gè)xxx,獲取headers值*/var.xxx = postman.getResponseHeader("key");3./*將Headers中的值設(shè)置為一個(gè)環(huán)境變量*/postman.setEnvironmentVariable("key",xxx);或者pm.environment.set("key",xxx);4./*檢查response的code值是否為200*/tests["Status code is 200"] = responseCode.code === 200; // tests["Status code is 200"]中的tests是一個(gè)內(nèi)置對(duì)象, /*tests["Status code is 200"]是指為這個(gè)斷言起個(gè)名稱(chēng)叫”Status code is 200”,這個(gè)名稱(chēng)可以自行修改。 responseCode.code === 200中的responseCode是內(nèi)置對(duì)象,responseCode對(duì)象中有個(gè)屬性是code,是指HTTP狀態(tài)碼的code,判斷code是否為200.綜合起來(lái),這句代碼的意思是:名稱(chēng)為”Status code is 200”的斷言中,判斷responseCode對(duì)象的code屬性值(HTTP狀態(tài)碼)是否為200。*/5./*檢查response的body中是否包含字符串 */ tests["Body matches string"] = responseBody.has("type"); // tests["Body matches string"]中的tests是一個(gè)內(nèi)置對(duì)象, /*tests["Body matches string"]是指為這個(gè)斷言起個(gè)名稱(chēng)叫”Body matches string”,這個(gè)名稱(chēng)可以自行修改。 這句代碼的意思是:名稱(chēng)為”Body matches string”的斷言中判斷響應(yīng)正文中是否包含:type這個(gè)字段。type無(wú)論是key或者value,只要匹配就可以。多個(gè)類(lèi)型可用“,”分割。*/6./*檢查response的body中是否包含字符串 */ 檢查Response Body是否等于字符串 tests["測(cè)試點(diǎn)"] = responseBody === "Response Body返回的內(nèi)容";//這個(gè)可以用在接口返回內(nèi)容為純字符串時(shí),直接檢查整個(gè)返回結(jié)果的正確性7./*檢查Response time 是否小于200ms */tests["Response time 小于200毫秒"] = responseTime < 200;8./*檢查Response time 是否大于200ms */tests["Response time 大于200毫秒"] = responseTime > 200;9./*檢查response的body中是否包含字符串 */ postman.setNextRequest('Request 4') // postman.setNextRequest()是一個(gè)帶有一個(gè)參數(shù)的函數(shù),它是接下來(lái)要運(yùn)行的請(qǐng)求的名稱(chēng)或ID。往往用來(lái)跳轉(zhuǎn)至某個(gè)接口,只在運(yùn)行該集合時(shí)有用,單獨(dú)運(yùn)行無(wú)效10./*轉(zhuǎn)換XML body為JSON對(duì)象 */var jsonObject = xml2Json(responseBody);11./*設(shè)置一個(gè)隨機(jī)數(shù)變量 */pm.globals.set("type",parseInt(4*Math.random())+1); //針對(duì)不同類(lèi)型的課程類(lèi)型,設(shè)置一個(gè)1到4的隨機(jī)整數(shù),字段名是type,parselnt 是強(qiáng)制轉(zhuǎn)換為整數(shù)12./*校驗(yàn)接口返回是否有數(shù)據(jù) */tests["獲取第一個(gè)結(jié)果"] = xxx.content.jieguo[0];//程序設(shè)置的是如果當(dāng)前沒(méi)有數(shù)據(jù),則只返回content[],所以這句斷言可以校驗(yàn),如果content里還有數(shù)據(jù),則視為返回不為空5 使用postman進(jìn)行接口自動(dòng)化測(cè)試
首先,既然是自動(dòng)化測(cè)試,那么我們肯定需要工具 (Postman) 或者代碼能幫我們直接判斷結(jié)果是否符合預(yù)期。那么在接口測(cè)試上,大體就兩個(gè)思路:
判斷請(qǐng)求返回的 code 是否符合預(yù)期
判斷請(qǐng)求返回的內(nèi)容中是否包含預(yù)期的內(nèi)容(關(guān)鍵字)
接下來(lái)我們看看如何利用 Postman 來(lái)解決上述的問(wèn)題:
step1. 這是兩個(gè)模擬天氣的接口集合,點(diǎn)擊擴(kuò)展按鈕,找到RUN,進(jìn)入
step2. 先簡(jiǎn)單運(yùn)行一次:
運(yùn)行成功!
6 附錄
在此推薦一款很好的谷歌瀏覽器插件Talend API Teste
直接通過(guò)谷歌網(wǎng)上商店搜索安裝即可!
安裝完畢就可以進(jìn)行接口測(cè)試?yán)?#xff01;如下圖:
操作與Postman大同小異,趕快試試吧!
總結(jié)
以上是生活随笔為你收集整理的Postman使用小教程--基础入门篇的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 基于机器视觉的散热器钎焊缺陷检测系统研发
- 下一篇: Zookeeper默认占用8080端口问