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

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

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的核心思想是測試先來,實現后來。但如何測試并沒有列規定非要用代碼,所以根據實際情況,選擇最佳的測試手段。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: aigao视频 | 亚洲理论视频 | 好男人好资源在线观看免费 | 日本护士厕所xxx | 久久国产乱子伦精品免费不卡 | 青草国产 | 四虎国产精品视频免费看 | 好吊日在线 | 亚洲精品久久久久久婷婷 | 日本在线亚州精品视频在线 | 我的男友是消防员在线观看 | 亚洲国产精品无码中文字幕 | 国产综合图区 | 欧洲美女啪啪 | hezyo加勒比一区二区三区 | 婷婷在线观看香蕉五月天 | 国产成人精品实拍在线 | 国产日韩欧美视频 | 摸逼小说| 欧美一二区 | 国产99在线a视频 | 动漫美女强行被吸乳做羞羞事 | 欧美日韩在线一区 | 美妇在男人胯下哀求 | 91免费永久国产在线观看 | 九哥草逼网| 4hu永久地域网名入口 | 国产肥老上视频 | 欧美精品一区二区在线观看 | 动漫美女被吸乳 | 国产3p绿奴在线视频 | 1024免费观看完整版在线播放 | 九九精品视频在线观看九九 | 成人免费影 | caoporen97免费公开视频 | 色综合亚洲精品激情狠狠 | 女性全身裸露无遮挡 | 非洲一级毛片又粗又长aaaa | 麻豆小视频在线观看 | 草莓视频在线免费观看 | 99视频有精品视频免费观看 |