麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 系統 > Android > 正文

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

2020-04-11 12:23:32
字體:
來源:轉載
供稿:網友
最近部分采用了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精品视频 | 一区二区精品视频在线观看 | 日本欧美在线播放 | 中文字幕在线免费观看电影 | 久久这| 国产资源在线看 | 黄污在线观看 | 毛片视频网站在线观看 | 国产黄网 | 91精品国产91久久久久久吃药 | 中文字幕免费看 | 在线成人亚洲 | 成人午夜免费福利 | 国产精品九九久久一区hh | 午夜视频亚洲 | 久久精品性视频 | 久草在线视频福利 | 毛片电影网址 | 欧美成人一区二区视频 | 精品免费在线视频 | 欧美成人小视频 | 国产精品69久久 | 国产成人精品无人区一区 | 男女羞羞在线观看 | 国产一级毛片高清视频完整版 | 亚洲乱码精品久久久久 | 成人免费入口 | 欧美成人久久 | 一级黄色淫片 | 黄色av电影在线播放 | 久久亚洲美女视频 | 97zyz成人免费视频 | 久在线观看福利视频69 | av手机在线电影 |