1 前言
對(duì)于接口測(cè)試,我嘗試過(guò)自己寫接口測(cè)試框架渤闷,也嘗試使用一些開(kāi)源的框架進(jìn)行二次開(kāi)發(fā)使用惶桐,最后我還是選擇了postman,一方面由于我工作本身淀歇,很多情況下我需要同時(shí)負(fù)責(zé)好幾個(gè)項(xiàng)目易核,接口測(cè)試只是我眾多工作中的一小部分,所以postman就成為了我最好的選擇浪默,搭建快牡直,維護(hù)成本少,另一方面postman的功能強(qiáng)大纳决,對(duì)于一般項(xiàng)目的接口測(cè)試的要求完全能夠滿足碰逸。 所以如果你的項(xiàng)目規(guī)模不大的話,postman能給你工作帶來(lái)很大的便利性岳链。
另外花竞,本系列內(nèi)容不求最全(全的話,postman官網(wǎng)本身就很全)掸哑,只求最實(shí)用约急,提到的部分都是目前我項(xiàng)目中在使用的,也的確解決了項(xiàng)目的一些問(wèn)題和提升了工作效率苗分。
本系列會(huì)覆蓋的范圍有:
* POSTMAN 基礎(chǔ)操作
* 如何處理接口依賴
* 編寫測(cè)試代碼 (數(shù)據(jù)驅(qū)動(dòng)測(cè)試)
* 契約測(cè)試 tv4
* 性能測(cè)試
* mock 服務(wù)
* 定制你自己的接口文檔 blueprint
* CI/CD newman
* POSTMAN最佳實(shí)踐
* 可視化
今天講的是第一部分的內(nèi)容厌蔽,Postman的基本操作。下圖是postman常用的幾個(gè)模塊摔癣。我們接下來(lái)會(huì)一個(gè)個(gè)的介紹奴饮。
2 發(fā)送一個(gè)簡(jiǎn)單的請(qǐng)求
對(duì)于一個(gè)簡(jiǎn)單的請(qǐng)求只需要使用到圖1的模塊1,2和5
在模塊1中定義請(qǐng)求的內(nèi)容:
請(qǐng)求方法 (GET择浊,POST戴卜, PUT,PATCH琢岩,DELETE等)
url
參數(shù)
請(qǐng)求頭
認(rèn)證方式 (比較常見(jiàn)等有 API Key投剥,Bear Token,Basic Auth担孔,OAuth等)
-
請(qǐng)求體 (請(qǐng)求體中可以上傳文件江锨,如下圖吃警。)
在模塊2中查看想要的body:
- 響應(yīng)code
- 響應(yīng)大小
- 響應(yīng)時(shí)間
- 響應(yīng)
- 響應(yīng)頭
- 響應(yīng)cookie
-
可視化結(jié)果(如下圖)
發(fā)送請(qǐng)求通過(guò)點(diǎn)擊模塊5的Send按鈕
練習(xí):發(fā)送一個(gè)get請(qǐng)求,url http://httpbin.org/get?a=a
3 使用環(huán)境變量
前面我們已經(jīng)學(xué)會(huì)如何發(fā)送一個(gè)請(qǐng)求啄育,可是在實(shí)際的測(cè)試中同一個(gè)api需要在不同的環(huán)境進(jìn)行測(cè)試酌心。比如開(kāi)發(fā)環(huán)境,測(cè)試環(huán)境挑豌,預(yù)生產(chǎn)環(huán)境和生產(chǎn)環(huán)境安券,如果我們每個(gè)環(huán)境都寫一個(gè)請(qǐng)求,這樣會(huì)帶來(lái)2個(gè)問(wèn)題:
- 如果api的路徑發(fā)生變化浮毯,我們需要去四個(gè)環(huán)境的請(qǐng)求里修改完疫,增加工作量
- 增加api的數(shù)量,增大管理難度
此時(shí)我們可以考慮使用POSTMAN的環(huán)境管理债蓝。以 http://httpbin.org/get?a=a 為例壳鹤, “http://httpbin.org” 這個(gè)是域名, “/get”是路徑饰迹, “?a=a”是參數(shù)芳誓。 所以我們把域名加到環(huán)境變量中。
第1步:增加一個(gè)環(huán)境變量啊鸭,定義賦值 baseUrl锹淌。第2步:請(qǐng)求的url使用環(huán)境變量,環(huán)境變量通過(guò) {{變量名}} 來(lái)使用
從 http://httpbin.org/get?a=a 改為 {{baseUrl}}/get?a=a
環(huán)境變量里的變量是一個(gè)全局變量赠制,除了可以在url里使用赂摆,也可以在body里使用,甚至tests模塊里使用钟些。只需要使用雙引號(hào)加變量名即可烟号。
4 請(qǐng)求轉(zhuǎn)化成代碼
在有些情況下需要把請(qǐng)求轉(zhuǎn)成代碼或者curl的情況。比如某個(gè)請(qǐng)求出現(xiàn)問(wèn)題政恍,我們需要登陸服務(wù)器直接發(fā)送請(qǐng)求看下是否是網(wǎng)絡(luò)問(wèn)題汪拥,此時(shí)就需要curl。再比如當(dāng)初為我在寫newrelic的監(jiān)控的時(shí)候篙耗,就是直接把
postman的請(qǐng)求轉(zhuǎn)成nodejs的代碼迫筑,然后把代碼直接拷貝稍微修改下就可以在newrelic里使用。大大提高了工作效率宗弯。
同樣以之前的 http://httpbin.org/get?a=a 為例 脯燃,看下如何轉(zhuǎn)化成代碼。
只需要一步蒙保,點(diǎn)擊code按鈕 (圖1中的模塊6)曲伊,選擇需要轉(zhuǎn)化的語(yǔ)言即可。
5 導(dǎo)入代碼
有時(shí)候我們得到的可能是個(gè)curl,也可能是個(gè)postman的collection文件坟募,或者是一個(gè)swagger的json文件,此時(shí)我們就可以使用postman的導(dǎo)入功能邑狸,把這些轉(zhuǎn)化成postman的請(qǐng)求進(jìn)行使用懈糯。
操作只需要一步,點(diǎn)擊import按鈕(圖1中的模塊7)单雾,然后導(dǎo)入相應(yīng)的內(nèi)容赚哗。
6 Collection
當(dāng)請(qǐng)求數(shù)量多起來(lái),可以通過(guò)collections進(jìn)行管理硅堆,collections是一群請(qǐng)求的集合屿储。
collections下面還可以創(chuàng)建文件夾。通過(guò)collection和文件夾就可以用來(lái)組織你的請(qǐng)求渐逃,讓他們更有條理够掠。(collections就是圖1的模塊8)
collections 常見(jiàn)的操作有:
- 導(dǎo)出,可以導(dǎo)出成一個(gè)json文件
- 分享茄菊,可以生成一個(gè)分享鏈接
- mock
- monitor 具體如下圖
7 監(jiān)控
postman還提供了一些對(duì)于我們之后跑自動(dòng)化測(cè)試很有用的功能疯潭。我們可以根據(jù)情況定義:
- 接口運(yùn)行頻率
- 發(fā)送報(bào)告
- 指定地區(qū)
之后可以通過(guò)web 的monitor dashboard來(lái)查看接口跑的情況。