核心提示:測試,任何一個(gè)開發(fā)者都不愿意提起的話題,但是又不得不提。測試作為軟件開發(fā)的最后環(huán)節(jié)往往不被人重視,但往往就在這最后一
測試,任何一個(gè)開發(fā)者都不愿意提起的話題,但是又不得不提。測試作為軟件開發(fā)的最后環(huán)節(jié)往往不被人重視,但往往就在這最后一哆嗦,前面付出的諸多心血付之東流了。在軟件開發(fā)階段完成之后經(jīng)常嚴(yán)格的測試環(huán)節(jié)才能對外發(fā)布,測試是一個(gè)軟件邁向市場的最后環(huán)節(jié)。
當(dāng)進(jìn)入移動(dòng)互聯(lián)網(wǎng)時(shí)代,各個(gè)行業(yè)中涌現(xiàn)出來的App質(zhì)量良莠不齊,這是由于國內(nèi)整體的技術(shù)環(huán)境導(dǎo)致的,不重視測試。有人會(huì)說,Google不會(huì)對自己的應(yīng)用進(jìn)行測試,我們也可以學(xué)習(xí)Google。但Google的工程師都是領(lǐng)域內(nèi)頂尖的高手,你聘請的工程師呢?大部分公司出于成本考慮,會(huì)雇一些比較初級的開發(fā)人員,做出來的東西也是比較粗糙,而且還不測試,APP的質(zhì)量可想而知。
當(dāng)與一些創(chuàng)業(yè)者溝通交流的時(shí)候他們往往會(huì)有這樣的想法,先發(fā)布再說,有了用戶反饋在修改。就是這樣的想法讓好不容易有了的用戶群慢慢消散,因?yàn)楫?dāng)你出現(xiàn)問題的時(shí)候用戶就已經(jīng)有了卸載應(yīng)用的理由,為什么不將一個(gè)接近完美的產(chǎn)品放在用戶面前呢?
在與一些移動(dòng)創(chuàng)業(yè)者交流的過程中發(fā)現(xiàn),這并不是產(chǎn)品與研發(fā)不想做測試,而是由于根本沒有精力和成本來做測試。因?yàn)樵谝苿?dòng)互聯(lián)網(wǎng)領(lǐng)域版本快速迭代,采用傳統(tǒng)測試方式的話黃花菜都涼了。就目前的狀況來看,似乎只有自動(dòng)化測試者一條路可走,但傳統(tǒng)自動(dòng)化測試的模式真的能滿足移動(dòng)互聯(lián)網(wǎng)創(chuàng)業(yè)者的需求么?
傳統(tǒng)自動(dòng)化測試不是你想測就能測
首先傳統(tǒng)測試需要購買大量的測試設(shè)備,這對于初創(chuàng)型團(tuán)隊(duì)來講是一筆不小的成本,這些設(shè)備的購買成本甚至要比整個(gè)團(tuán)隊(duì)的日常運(yùn)作費(fèi)用還要高。如果考慮做自動(dòng)化測試,您還得雇幾個(gè)懂的人來搞,更是一大塊成本。所以自動(dòng)化測試雖然看上去很美,但很少有公司愿意去碰它,原因也是這里邊,前期需要投入的成本,是大部分公司不能接受的。
其次,傳統(tǒng)測試對于技術(shù)和時(shí)間的要求較高,不能適應(yīng)移動(dòng)互聯(lián)網(wǎng)快速版本迭代的現(xiàn)狀。在與某大型公司的測試經(jīng)理交流之后了解到,傳統(tǒng)測試也可以實(shí)現(xiàn)自動(dòng)化測試,但步驟比較繁瑣。
實(shí)現(xiàn)Android測試項(xiàng)目自動(dòng)化,需要一下幾個(gè)步驟:
1. 了解產(chǎn)品功能。
2. 評估手動(dòng)測試用例,篩選出適合自動(dòng)化的用例。
3. 搭建腳本開發(fā)環(huán)境(配置Eclipse,下載測試框架,安裝Android SDK,配置環(huán)境等)
4. 根據(jù)用例描述編寫測試腳本
5. 調(diào)試完善腳本
6. 執(zhí)行自動(dòng)化測試(可能需要搭建多個(gè)設(shè)備同時(shí)執(zhí)行測試的環(huán)境)
7. 腳本在應(yīng)用升級迭代中不斷地維護(hù)更新,并重復(fù)執(zhí)行
一位就職于國內(nèi)大型企業(yè)中的測試工程師介紹到,根據(jù)以往的經(jīng)驗(yàn),一般測試項(xiàng)目,可實(shí)現(xiàn)自動(dòng)化的測試用例比例大約為30% ~ 50%。有些手動(dòng)測試用例,需要進(jìn)行拆分才能較好的實(shí)現(xiàn)自動(dòng)化。類似于單元測試,UI自動(dòng)化測試,最好也是一條用例只驗(yàn)證一個(gè)測試點(diǎn),這樣有利于測試腳本的編寫和維護(hù)。
這還不包括后續(xù)編寫腳本與調(diào)試完善腳本的事情,假設(shè)我們已經(jīng)對測試用例進(jìn)行拆分,一條用例只驗(yàn)證一個(gè)測試點(diǎn)。這類測試用例,對于初級自動(dòng)化測試工程師來說,完成這樣一條用例的腳本的編寫和調(diào)試需要3~4個(gè)小時(shí),中高級的人員平均需要1個(gè)小時(shí)左右。到了測試腳本的后期維護(hù)階段,耗費(fèi)的時(shí)間更加不可預(yù)知。
在與這位測試工程師交流過后,感覺傳統(tǒng)的測試模式對于快速發(fā)展的移動(dòng)互聯(lián)網(wǎng)公司來說就是一個(gè)噩夢,一個(gè)耗時(shí)費(fèi)力的噩夢。
創(chuàng)業(yè)路上 喊上父母來解決傳統(tǒng)測試之痛
關(guān)于移動(dòng)應(yīng)用自動(dòng)化測試解決方案在市場上已經(jīng)有一些非常成熟的案例。這位不愿意透露姓名的測試工程師介紹到,目前市場上有幾個(gè)較為成熟的自動(dòng)化測試軟件可以用來輔助測試工作。
國內(nèi)目前使用比較廣泛的是iTestin,也有一部分人使用百度的MTC和易測云的Radar,但是從更新頻率和維護(hù)熱度上來看還是稍差一些,國外的自動(dòng)化測試工具以收費(fèi)的居多,其實(shí)核算下來成本并不低。
iTestin是國內(nèi)Testin云測公司推出了一款免費(fèi)的安卓自動(dòng)化測試腳本錄制工具iTestin,可以幫助你所在的項(xiàng)目組快速實(shí)現(xiàn)穩(wěn)定模塊的功能自動(dòng)化測試,或者實(shí)現(xiàn)某個(gè)版本的深度兼容性測試。
iTestin還可直接捕獲操作者在真實(shí)手機(jī)設(shè)備上對被測應(yīng)用的操作,并直接生成可跨分辨率執(zhí)行的功能測試腳本。該腳本能在應(yīng)用的多個(gè)版本間復(fù)用,并隨時(shí)可以提交云測平臺(tái),在1000多款真機(jī)上重復(fù)執(zhí)行。測試報(bào)告包括測試腳本包涵蓋的功能點(diǎn)的驗(yàn)證結(jié)果,還有測試過程中的日志、截圖、和性能數(shù)據(jù)等。通過使用iTestin,你可能只需一位黑盒測試工程師,就可以在一天之內(nèi)啟動(dòng)自動(dòng)化測試。
從另外一個(gè)角度來看,iTestin可以讓一個(gè)完全沒有測試經(jīng)驗(yàn)的人完成繁瑣而且機(jī)械的測試工作。換句話說,你甚至可以把你的父母喊來幫你做測試工作,在你創(chuàng)業(yè)的路上又添加了一抹戲劇化的元素。