提升測試效率?有了這些接口測試用例+工具都不是問題
寫在前面:在日常開發(fā)過程中,有人做前端開發(fā),有人負(fù)責(zé)后端開發(fā)。接口的主要作用就是連接前后臺。但是,由于前端和后端開發(fā)的速度可能不一樣,尤其是后端開發(fā)好了,但前端還未開發(fā)。這種時候我們需要做接口測試嗎?
在日常工作中,我們主要測試的都是功能板塊,如果你想真正了解接口測試,那么這篇文章或許能給你一定幫助。
1、為什么我們要做接口測試?
首先,我們先來看看測試金字塔(接口測試是在中間部分,底層是單元測試,最頂端是界面測試)。
從三者的面積大小來看,單元測試和接口測試,才是重點(diǎn),而界面測試真的是太少。這個面積,你可以理解為代碼覆蓋,也可以理解為測試的工作量。
這里要提出一個觀點(diǎn):現(xiàn)在國內(nèi)公司越來越重視接口測試了。之前的幾年,很多測試資源都放在了界面的測試,今后會逐步放在接口測試功能、性能、自動化和穩(wěn)定性測試上面。
白盒測試目前還是開發(fā)自己測試,有些大公司,注重軟件產(chǎn)品質(zhì)量,也會安排一些有代碼能力的測試人員,去輔助和指導(dǎo)開發(fā)人員進(jìn)行單元測試,共同保證軟件的質(zhì)量。
2、什么是接口測試?
這部分內(nèi)容可以說:前人之述備矣,我就不贅述了。(PS:需要的同學(xué)可以回復(fù):接口測試,查看相關(guān)文章。)
3、接口的分類
在開始做接口測試之前,有必要了解一下接口的分類。這里的分類,主要是HTTP請求方法分類。下面是我們最常見的GET/POST/PUT/DELETE四種方法。工作中接口用到最多是GET和POST方法。(GET和POST方法的具體區(qū)別,大家可以自行翻閱圖書查看)
4、設(shè)計接口測試用例
接下來,我們就一起來聊聊進(jìn)行接口測試的準(zhǔn)備工作。有些同學(xué)很好奇,接口測試要流程干嘛?不就是拿著接口文檔直接利用接口測試工具測試嘛。
其實,如果只是三五個接口,你可以這么做一個臨時的接口測試。但是,如果是上百個接口,或者,你們公司的這個項目,第一次做接口測試,那么,我們還是很有必要遵守測試的流程。
1)接口測試的流程
接口測試和功能測試一樣,流程也大致遵守V模型,請看下圖。
一般來說,接口測試左邊的每個階段,每個公司可能都側(cè)重點(diǎn)不同,例如有些公司就沒有需求討論和需求評審這個階段。不管如何,用例設(shè)計,這個是少不了,而且是重點(diǎn),要花時間的階段。只有覆蓋全面的接口測試用例,才能有比較好的測試接口覆蓋率,才會找出更多的接口的Bug。
2)為什么要寫接口測試用例
功能測試用例,大家都寫過。接口測試用例,很多人沒有寫過。在寫之前,我們來討論下,為什么要寫接口用例。
①理清思路,避免漏測
②提高測試效率
③跟進(jìn)測試進(jìn)度
④告訴領(lǐng)導(dǎo)做過
⑤跟進(jìn)重復(fù)性工作
上面五點(diǎn),結(jié)合自己測試實際經(jīng)驗,應(yīng)該來說是很好理解和認(rèn)同的。有用例,就有思路,避免漏掉測試點(diǎn)。跟著測試用例走,一方面,可以避免隨機(jī)測試那種沒有目的性的測試,提高測試效率;另一方面,這對領(lǐng)導(dǎo)檢查你的工作、同事詢問你的進(jìn)度時有很多便利,也能夠提高對接效率。
3)接口用例設(shè)計
我們在設(shè)計接口用例時,主要可以從這四個方面來考慮:功能,邏輯業(yè)務(wù),異常,安全。
①功能:
功能是否正常;功能是否按照接口文檔實現(xiàn);
舉例:有些添加到購物車,需要登錄才能添加。也就是業(yè)務(wù)要求不支持游客添加購物車功能,如果設(shè)計一個沒有登錄的用戶,然后去測試添加購物車接口,結(jié)果接口能添加到購物車,說明功能不正常,不符合需求和接口文檔描述。
②邏輯業(yè)務(wù):
是否依賴業(yè)務(wù);
舉例:該接口調(diào)用之前,需要調(diào)用登錄接口,如果不登錄也能請求數(shù)據(jù),不符合業(yè)務(wù)規(guī)則。
③異常:
參數(shù)異常和數(shù)據(jù)異常;
參數(shù)異常:關(guān)鍵字參數(shù),參數(shù)為空,多,少參數(shù),錯誤參數(shù);
數(shù)據(jù)異常:關(guān)鍵字?jǐn)?shù)據(jù),數(shù)據(jù)為空,長度不一致,錯誤數(shù)據(jù);
舉例:不管數(shù)據(jù)異常還是參數(shù)異常,測試點(diǎn)差不多,一個參數(shù)有key和value,key表示參數(shù),value表示數(shù)據(jù)。
第一,看看參數(shù)和數(shù)據(jù)能不能支持關(guān)鍵字,例如Java中的保留關(guān)鍵字等等;
第二,就是參數(shù)和數(shù)據(jù)都為空,看看是否做了判斷;
第三,參數(shù)多和少,例如有兩個參數(shù)的接口,你需要設(shè)計一個三個參數(shù)的用例,一個只有一個參數(shù)的用例。數(shù)據(jù)那邊長度不一致,例如設(shè)計很長的字符串是否支持,因為數(shù)據(jù)庫創(chuàng)建表過程都設(shè)置好了每個字段的長度。輸入錯誤的參數(shù)和數(shù)據(jù),例如故意輸出單詞等等。
④安全測試用例設(shè)計:
cookie:有cookie才能獲取數(shù)據(jù),如果不帶cookie還有信息返回,說明有問題
header:正常接口帶header信息,刪除header看是否能夠返回數(shù)據(jù)。
唯一識別碼:app手機(jī)識別碼,一般是唯一的。
注:安全測試主要從上面三點(diǎn)檢查。第三個是唯一識別碼,主要是指app上手機(jī)的識別碼,一般很少用到,除非很嚴(yán)格的接口測試,例如銀行app登錄,需要指紋,而指紋來源手機(jī),一般有一個手機(jī)識別碼判斷過程。
5、接口測試的工具
目前,市場上有很多支持接口測試的工具。利用工具進(jìn)行接口測試,能夠提供測試效率。例如,加入讓你一天完成100個接口測試任務(wù),你覺得你加班能否完成。如果有工具,但是不是所有工具都能夠支持你完成這個任務(wù)。下面我們就來挑選幾個工具,簡單介紹一下。
1)fiddler
首先,這是一個HTTP協(xié)議調(diào)試代理工具,說白了就是一個抓http包的工具。web測試和手機(jī)測試都能用到這個工具。既然是http協(xié)議,這個工具也能支持接口測試。稍后文章,我們會專門介紹fiddler這個工具。
2)postman
這是一款google工程師開發(fā)的一個插件,可以安裝到chrome瀏覽器上。支持不同接口測試請求,能夠管理測試套件和自動化運(yùn)行,弱點(diǎn)在于,自動化斷言功能不強(qiáng)大。不能和jenkins和代碼管理庫進(jìn)行持續(xù)集成測試。但是,絕對是一個很好的半手工,半自動化測試工具,我一般在寫自動化接口測試用例,會打開postman進(jìn)行輔助測試和debug。這個工具也會稍后在文章介紹。
3)wireshak
這個是一款計算機(jī)上抓包工具,支持抓各種包,TCP,UDP,HTTP都支持。如果做底層網(wǎng)絡(luò)數(shù)據(jù)測試,一般都需要用到它。作為接口測試,這個軟件有點(diǎn)不友好。因為刷新數(shù)據(jù)太快,不好定位每個操作對應(yīng)的接口。所以,我們不會進(jìn)行過多介紹這個工具。
4)soupUI
這個是一個開源免費(fèi)、企業(yè)版收費(fèi)的軟件。在國外的接口測試,使用非常多。這個工具能夠支持接口自動化測試和接口性能測試,也能支持和jenkins做持續(xù)集成測試。了解一下就可以,自己可以下載一個社區(qū)免費(fèi)版,做一個demo試試。
5)java代碼做接口測試
代碼是萬能,筆記工具也是代碼開發(fā)出來的。為什么要用代碼做接口自動化測試呢。因為,有些工具功能是有限制,很多公司,需要一些特定的功能,工具不支持,只好用代碼進(jìn)行開發(fā)。
一般用Java做自動化測試,主要是利用httpclient.jar這個包,然后利用junit或者testng這樣的單元測試工具,進(jìn)行測試用例的開發(fā),然后在jenkins上創(chuàng)建一個job,進(jìn)行持續(xù)集成測試。
6)Python代碼做接口測試
和Java一樣,Python中利用一個很好,功能強(qiáng)大的第三方庫requests,能夠方便都創(chuàng)建接口自動化用例。python下單元測試框架,一般采用unittest。生成測試報告,一般選擇HTMLTestRunner.py。同樣,可以和jenkins做持續(xù)集成測試。
7)LoadRunner
不要以為LR只能做性能測試,loadrunner同樣可以做接口自動化和接口壓力測試。只是我們很多人,不會利用LR的函數(shù),進(jìn)行開發(fā)接口測試用例。
8)JMeter
JMeter同loadrunner一樣,都是以性能測試出名,一般用JMeter也是做接口性能測試。例如java+Jmeter+ant+jenkins做接口性能監(jiān)聽測試。JMeter如何做接口測試,大家可以網(wǎng)上查下。
寫在最后:上面說了這么多工具,基本覆蓋了接口功能測試,接口自動化測試,接口性能測試。這里提一下,在Python語言下有一個性能測試工具推薦:Locust。自己百度,安裝下,很簡單的web界面,感覺很不錯,作為一個輕量級的協(xié)程測試工具。