昨晚在某個(gè)測試交流群,聽了一個(gè)測試?yán)纤緳C(jī)分享接口自動(dòng)化測試的內(nèi)容,對(duì)接口自動(dòng)化有了更深的一些認(rèn)識(shí),也為接下來公司的接口自動(dòng)化實(shí)施,提供了更多的思路。
這篇文章,就說說功能測試到接口自動(dòng)化的進(jìn)階,以及接口自動(dòng)化的一些事。。。
前言
自動(dòng)化測試,算是近幾年比較火熱的一個(gè)話題,當(dāng)然,更是軟件測試未來的一個(gè)發(fā)展趨勢。未來,功能測試等非核心的測試工作,都將被外包。
想要在軟件測試這個(gè)行業(yè)繼續(xù)前行,就必須擁有核心競爭力,掌握自動(dòng)化測試技術(shù),是必不可少的一個(gè)技能。
在《Google軟件測試之道》一書中有介紹到:在Google,70%的自動(dòng)化測試工作集中于單元測試,20%集中于接口測試,剩下10%才是UI測試。
誠然,我們沒有Google那么完善的機(jī)制和工程師文化,沒必要一切照搬Google,但Google作為互聯(lián)網(wǎng)2.0時(shí)代最耀眼的一個(gè)公司,它的技術(shù)發(fā)展方向,流程管理等可以說是不久的將來,我們也要到達(dá)的方向。選擇適合自己的,落地應(yīng)用,是當(dāng)下我們應(yīng)該做的。
目前國內(nèi)的互聯(lián)網(wǎng)行業(yè),大環(huán)境來說,還處在一個(gè)快速發(fā)展,需要流程化標(biāo)準(zhǔn)化的時(shí)期,如何跟上不斷變幻發(fā)展的節(jié)奏,除了不斷了解接觸新的東西,還需要不斷學(xué)習(xí),提升自身,以內(nèi)在的驅(qū)動(dòng)力,去緊跟時(shí)代浪潮。即使做不了弄潮兒,也不能變成時(shí)代淘汰的那一批。

01、接口測試的必要性和意義
接口,即API,應(yīng)用程序編程接口,關(guān)于接口的介紹。
這里主要說說接口測試的必要性和意義:
接口測試實(shí)施在多系統(tǒng)的平臺(tái)架構(gòu)下,有著極為高效的成本收益比(當(dāng)然,單元測試收益更高,但實(shí)施單元測試的成本投入更大,技術(shù)要求更高,所以應(yīng)該選擇更適合自身的才是最好的方案)。
接口測試天生為高復(fù)雜性的平臺(tái)帶來高效的缺陷檢測和質(zhì)量監(jiān)督能力,平臺(tái)復(fù)雜,系統(tǒng)越龐大,接口測試的效果越明顯。
總的來說,接口測試是保證高復(fù)雜性系統(tǒng)質(zhì)量的內(nèi)在要求和低成本的經(jīng)濟(jì)利益驅(qū)動(dòng)作用下的最佳方案,主要體現(xiàn)在如下三個(gè)方面:
1、節(jié)省了測試成本
根據(jù)數(shù)據(jù)模型推算,底層的一個(gè)程序BUG可能引發(fā)上層的8個(gè)左右BUG,而且底層的BUG更容易引起全網(wǎng)的死機(jī);接口測試能夠提供系統(tǒng)復(fù)雜度上升情況下的低成本高效率的解決方案。
2、接口測試不同于單元測試
接口測試是站在用戶的角度對(duì)系統(tǒng)接口進(jìn)行全面高效持續(xù)的檢測。
3、效益更高
將接口測試實(shí)現(xiàn)為自動(dòng)化和持續(xù)集成,當(dāng)系統(tǒng)復(fù)雜度和體積越大,接口測試的成本就越低,相對(duì)應(yīng)的,效益產(chǎn)出就越高。
02、做接口測試需要哪些技能
做接口測試,需要的技能,基本就是以下幾點(diǎn):
業(yè)務(wù)流:了解系統(tǒng)及內(nèi)部各個(gè)組件之間的業(yè)務(wù)邏輯交互;
數(shù)據(jù)流:了解接口的I/O(input/output:輸入輸出);
協(xié)議:包括http協(xié)議,TCP/IP協(xié)議族(之前的博客有系統(tǒng)的介紹過協(xié)議,傳送門:http協(xié)議:菜鳥入門系列)
工具:工具可以輔助我們更好更高效的完成工作,常用的接口測試工具有:jmeter、loadrunner、soapui、postman等;
數(shù)據(jù)庫知識(shí):無論是從數(shù)據(jù)庫獲取知識(shí),還是確認(rèn)數(shù)據(jù)落地,抑或接口對(duì)數(shù)據(jù)執(zhí)行了哪些操作,都需要確認(rèn),因此數(shù)據(jù)庫知識(shí)(其實(shí)就是增刪改查)就很有必要;
補(bǔ)充:接口文檔的幾個(gè)必要點(diǎn):完整性、一致性、容錯(cuò)性;
整理了一些軟件測試方面的資料、面試資料(接口自動(dòng)化、web自動(dòng)化、app自動(dòng)化、性能安全、測試開發(fā)等),有需要的小伙可以加入我的qq學(xué)習(xí)交流群110685036,無套路自行領(lǐng)取~?
03、接口自動(dòng)化測試
1、如何開展
首先,調(diào)試單個(gè)接口,保證單個(gè)接口的正確和通暢(類似于性能測試中的基準(zhǔn)測試);
其次,明確數(shù)據(jù)流,業(yè)務(wù)流;
最后,將N個(gè)接口測試腳本串起來,執(zhí)行即可;
最重要的一點(diǎn),別想太多太復(fù)雜,先把最基礎(chǔ)最簡單的做起來,就成功一大半了,至于擴(kuò)展性的第三方接口、https、定時(shí)任務(wù)、自動(dòng)出測試報(bào)告、自動(dòng)發(fā)郵件等等功能,這都是不斷累計(jì)和優(yōu)化的,
行動(dòng)起來就行,想太多不如行動(dòng)起來,讓接口自動(dòng)化測試落地,才是我們首先需要考慮的
2、開展之前需要知道的
現(xiàn)在的測試對(duì)象包含幾個(gè)頁面?
每個(gè)頁面涉及幾個(gè)接口?
分別在哪一步調(diào)用?
每個(gè)接口包含哪些字段?
各個(gè)字段對(duì)應(yīng)數(shù)據(jù)庫哪張表?
每個(gè)表中各個(gè)字段是什么意思?
各個(gè)接口對(duì)表產(chǎn)生了怎樣的操作?
3、自動(dòng)化框架
什么是框架?你可以理解為一個(gè)完整的環(huán),也可以理解為讓接口測試腳本運(yùn)行的一整套環(huán)境,平臺(tái),隨便什么都可以;一般一個(gè)自動(dòng)化測試框架包含以下幾點(diǎn):
數(shù)據(jù)池:即測試數(shù)據(jù)的存儲(chǔ)管理,一般集成為一個(gè)data包,其中包括:
log(日志文件)、report(測試報(bào)告文件,一般為xml格式)、case-data(單個(gè)接口的測試數(shù)據(jù),一般為json格式)、server-data(接口業(yè)務(wù)串聯(lián)的數(shù)據(jù),可以用excel管理)
腳本管理中心:接口測試腳本的統(tǒng)一管理、存儲(chǔ)、調(diào)度中心,常用的工具有maven、ant等,或者可以使用編程語言中的單元測試框架提供的功能,選擇自己適用的即可;
運(yùn)行平臺(tái):一般是借助工具來運(yùn)行這些測試腳本,工具可以使用上面提及到的幾種(jemter、loadrunner、soapui等),同樣,選擇合適的很重要;
持續(xù)集成工具:最常見的就是Jenkins,它的作用就是監(jiān)控外部程序的調(diào)用執(zhí)行,定時(shí)或者觸發(fā)調(diào)度任務(wù),測試腳本執(zhí)行等功能;
通信服務(wù):dubbo、spring_boot、thrift等RPC、REST同步調(diào)用服務(wù);
測試結(jié)果統(tǒng)計(jì)管理中心:比如testlink,目的是為了測試結(jié)果自動(dòng)更新上傳,更好的統(tǒng)計(jì)測試結(jié)果,以便后期的優(yōu)化;
上面說了這么多,實(shí)際上它的意義就是:數(shù)據(jù)與腳本分離,測試結(jié)果自動(dòng)提交通知,提高測試腳本和測試數(shù)據(jù)的維護(hù)便利等等。。。
我正在使用的框架為:jemter+maven+Jenkins+dubbo+MySQL......
關(guān)于接口自動(dòng)化測試,基本就是上述的內(nèi)容,當(dāng)然,選擇適合自身實(shí)際情況的框架,落地實(shí)施,才是重點(diǎn),行動(dòng)起來,才能咸魚翻身。。。
最后感謝每一個(gè)認(rèn)真閱讀我文章的人,看著粉絲一路的上漲和關(guān)注,禮尚往來總是要有的,雖然不是什么很值錢的東西,如果你用得到的話可以直接拿走

這些資料,對(duì)于做【軟件測試】的朋友來說應(yīng)該是最全面最完整的備戰(zhàn)倉庫,這個(gè)倉庫也陪伴我走過了最艱難的路程,希望也能幫助到你!凡事要趁早,特別是技術(shù)行業(yè),一定要提升技術(shù)功底。希望對(duì)大家有所幫助…….【可看個(gè)人介紹】