一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Android - Android開發筆記之:對實踐TDD的一些建議說明

Android開發筆記之:對實踐TDD的一些建議說明

2021-01-16 14:11Android開發網 Android

本篇文章是對Android中實踐TDD的一些建議進行了詳細的分析介紹,需要的朋友參考下

最近部分采用了TDD的方法來開發一個模塊,小有收獲特此總結一下:
1. TDD的基本原則

TDD的最核心思想就是先明確需求,且用代碼的方式量化,明確需求標準,然后進行編碼實現以達成由代碼測試來衡量的標準。
那么它要求,先把需要標準寫出來,每次只寫一個。編碼實現通過達到,并剛好滿足這個標準。這樣一點一點的迭代。
這樣有三個好處:一個是先明確標準,不至于我們迷失主題,偏離方向。有標準在檢測,保證代碼是正確的。僅滿足當前測試,不至于過早優化和過度設計。
2. TDD的難點
難點在于如何設計這個測試標準,
1)讓它足夠小,是一個需求單元;
2)成為標準,也就是如何檢測正確性;
3)就是如何在最大程度模擬真實運行的場景,而不是為了測試而寫出許多額外的工具,也就是說測試應該跟真實的項目代碼一樣,不應該有多余的東西。

這關鍵在于要分析挖掘需求,并細化需求。如果都像書中的例子那樣測試一些API那倒是很好寫,因為測試代碼跟真實的App代碼用一樣的方式來調用API,而且API的功能也會有明確的描述。但現實情況并非如此,比如很多框架就很難測試,很多對象和創建和控制都是由框架來做,你無法像控制。這就導致了很難寫測試用例。
還有就是多線程,由于線程帶來的不確定性,有很多偽失敗,這可以參考書,書中有方法。
3. Android中的TDD
老實說,在Android完全用TDD的方法來開發是不可能的。原因如下:

1. Android中的應用程序主要結構是四大組件:Service,Activity和Provider和Receiver這四東西的創建和銷毀都是由框架來控制。所以你不可能像書中例子那樣去測試它們,因為有些限制讓你無法用代碼來測試。
2. 有些東西是系統框架的回調或者很基本東西根本不用寫TestCase。比如View的Click/LongClick/Touch事件的處理之類的,或者Activity的生命周期回調,或者OptionsMenu/ContextMenu之類的。
3. SDK中的用于測試的API功能太弱
這就導致了,為了測試一個小功能需要做很多工作和寫很多代碼,遠大于直接實現。比如測試一個彈出的Dialog,如果直接實現很容易;但如果用代碼來測試就要多3,4倍的工作量,遠大于直接實現。
4. 那么在Android中應該如何運用好TDD呢?以下是一些建議:
1. 使用Robotium

這是強大的工具,它比SDK中的東西可是方便的很多比如searchText,clickMenu之類的接口非常的方便和實用。
2. 自動測試+手動測試
同樣要遵循原則,但是對于測試用例,沒有必要完全用代碼來寫,可以部分手動測試:一般的原則來講如果自動測試比較方便的實現就寫TestCase,如果手動測試很方便就手動測試,這沒有死規則要看具體的情況。
比如,View的事件,Activity的事件,Activity的Menu,Dialog之類的與交互相關的東西,以及跨應用交互的用例最好手動來測試,因為這些東西用代碼來測試更麻煩。
但對于一些涉及數值,計算,量化等就用代碼來做。比如下載一個文件,設定好路徑后就可以直接用File對象來檢測文件是否下載成功。
3. Provider必須要測試
Provider提供的是API,它非常好測試也容易寫,又是一個項目的基本設施,所以必須要好好測試,否則如果在Activity上某條數據有問題,你必須要確定是顯示上出了問題還是Provider里出了問題。通常CRUD必須測試,還有就是where語句,以及逆向測試,必須要檢測Uri的合法性等,還有就是要檢測對特殊字符的處理,比如'和"。
4. 除Service和Activity以外的東西,特別是自己實現的類似API的類,如果里面涉及一些業務邏輯也要進行測試。這就跟書中的例子差不多了,測試的難易成就也取決于業務的分解,設計和耦合度了。
5. 用反射來測試類的內部
對于Service和Activity雖然可以在TestCase中拿到它的實例,但是Service和Activity是一個組件單元在實際中并不會Public太多的接口,它們是處于最頂端的調用其他接口,而自己不會,也不應該公開接口給別人用,原因就是它們的創建和生命周期的管理都是由系統控制的,別處不應該有太多對它們的引用。
那么當要測試Service和Activity內部時怎么辦呢?比如要測試某個Service內部的一個int[] mPlaylistQueue。我們總不能為了寫Case而在Service中加接口吧!這時就要用反射機制來取出這個成員的實例,然后檢查它的數據。
6. 有些東西必須手動測試,自動化無法完成
TestCase是有特殊的Context和MockObject的,它是對真實Android運行的一個最大化的模擬,它并不跟應用真正運行時的情況完全一樣!而且由于Permission的原因,某些事情Instrumentation是無法做的,比如Alarm,日期等Instrumentation是無權限更改的。這些必須要靠手動測試。
還有就是Service和Activity的初始化和銷毀,特別是銷毀,沒辦法測試,也就是說對于onDestroy()里面的東西,還真的不好去測試。第一,你不知道它何時被回調到;第二,執行到它時對象快被銷毀了,你持有的引用不一定有效了;第三,成員對象是否都有效也無法得知。對于onDestroy只能通過調試手段手動的去測試。
總之,在我看來,TDD的核心思想是測試先來,實現后來。但如何測試并沒有列規定非要用代碼,所以根據實際情況,選擇最佳的測試手段。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 99操视频| 校园全黄h全肉细节文 | xxxx泡妞中国 | 99视频在线看 | sss在线播放| 久久九九精品国产自在现线拍 | 欧美黑人性猛交╳xx╳动态图 | 手机看片1024日韩 | 国产成人亚洲精品一区二区在线看 | 欧美成人三级伦在线观看 | 美女林柏欣21p人体之仓之梦 | 天堂网在线网站成人午夜网站 | 日韩亚洲国产欧美精品 | 99精品国产自在现线观看 | 亚洲国产一区二区三区青草影视 | 精品一区二区三区免费视频 | 99成人免费视频 | 我要看靠逼片 | 51国产午夜精品免费视频 | 国产欧美一区二区三区免费 | 成人影院在线观看视频 | 午夜福利试看120秒体验区 | 亚洲经典| 精品国产91高清在线观看 | 国产成人精品综合在线观看 | www.99热 | poren黑人 | 国产福利免费看 | 国内精品露脸在线视频播放 | 欧美精品综合一区二区三区 | 97视频人人| 日本粉色视频 | 国产精品夜色视频一级区 | 国产亚洲sss在线播放 | 国产精品亚洲片在线不卡 | 国产亚洲人成网站在线观看不卡 | 91短视频社区在线观看 | 紧身短裙女教师波多野 | 色婷婷久久综合中文久久一本 | 日本大学生xxxxx69泡妞 | 欧美人与禽交片在线播放 |