我的TDD感悟(二)--TDD的“紅”

在我的TDD感悟(一)中啊犬,說到了測試用例的重要性灼擂。當完成了測試用例的編寫,我們可以進入到TDD中的“紅”觉至,也就是單元測試代碼的編寫剔应。

測試用例和測試代碼

有了測試用例文檔,那么測試代碼就容易編寫多了语御。有了測試用例相當于定了一個測試目標峻贮,這個時候可以先評估測試用例,看哪個測試用例是最重要的应闯。優(yōu)先度最高的用例纤控,可以優(yōu)先挑選出來先實現(xiàn)

測試代碼要盡可能的簡單

單元測試一般采用3A模式(Arrange,Act碉纺,Assert)船万。代碼量不宜太多。單元測試本身也是代碼骨田,測試代碼本身不會再被驗證是否正確耿导。因此測試代碼越是簡單,就越容易判斷測試代碼是否正確态贤。否則一旦執(zhí)行的時候舱呻,當測試條變?yōu)榧t色的時候,不好排查是測試代碼有問題抵卫, 還是被測試代碼有問題狮荔。增加了排查難度

在寫測試代碼的時候需要考慮以下幾個點:

  • 被測試的類名是什么(這個時候就需要考慮類的職責問題了)
  • 被測試的API的名字,參數(shù)和返回值(這個時候考慮的是功能點的設計和API的易測性)
  • 最容易編寫的測試代碼是調(diào)用一個API介粘,然后通過API的返回值殖氏,調(diào)用Assert進行驗證。所以被測試的API在設計的過程中姻采,如果能符合冪等性雅采,那么測試會更容易做一些。且這個API日后的可維護性也會增強,并且比較容易保證質(zhì)量婚瓜。

這里主要還是強調(diào)類API的設計宝鼓, 雖然大腦會不自覺的考慮到具體算法。但是畢竟沒有真正的寫代碼巴刻,所以還不會陷入到代碼細節(jié)里愚铡。大腦還是比較容易聚焦于設計上

如果一個測試代碼需要多久寫完

  • TDD里的測試代碼不一定是一口氣寫完的。有些會根據(jù)后續(xù)的算法和重構胡陪,進行相應的修改
  • 一般TDD里的一個循環(huán)(紅->綠->重構)的周期不要太長沥寥,2~3分鐘為一個周期會合適些,這樣在出問題的時候柠座,比較容易縮小范圍邑雅,縮短排查的時間。所以當我們把API的類和函數(shù)寫完后妈经,剩下的測試代碼編寫應該要在短時間內(nèi)就能完成
  • 如果單元測試代碼需要寫很久淮野,要有非常多的前置條件滿足,才能測試對應的API吹泡≈栊牵或者在驗證結(jié)果的正確性時,需要很多代碼才有辦法驗證(比如要獲得某個全局變量才能驗證等等)這個時候我們需要考慮:我們的測試力度是否太大了(是否變成了集成測試)荞胡,或者我們的API設計的太復雜了妈踊,不符合冪等性

綜上所述,單元測試代碼越簡單泪漂,也會讓程序員愿意往下接著按TDD的方式寫代碼廊营。否則容易出現(xiàn)的一個現(xiàn)象就是:放棄

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市萝勤,隨后出現(xiàn)的幾起案子露筒,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異安接,居然都是意外死亡,警方通過查閱死者的電腦和手機瘪吏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蜗巧,“玉大人掌眠,你說我怎么就攤上這事∧灰伲” “怎么了蓝丙?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵级遭,是天一觀的道長。 經(jīng)常有香客問我渺尘,道長挫鸽,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任鸥跟,我火速辦了婚禮丢郊,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘医咨。我一直安慰自己蚂夕,他們只是感情好,可當我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布腋逆。 她就那樣靜靜地躺著,像睡著了一般侈贷。 火紅的嫁衣襯著肌膚如雪惩歉。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天俏蛮,我揣著相機與錄音撑蚌,去河邊找鬼。 笑死搏屑,一個胖子當著我的面吹牛争涌,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播辣恋,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼亮垫,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了伟骨?” 一聲冷哼從身側(cè)響起饮潦,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎携狭,沒想到半個月后继蜡,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡逛腿,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年稀并,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片单默。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡碘举,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出雕凹,到底是詐尸還是另有隱情殴俱,我是刑警寧澤政冻,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站线欲,受9級特大地震影響明场,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜李丰,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一苦锨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧趴泌,春花似錦舟舒、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至吉捶,卻和暖如春夺鲜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背呐舔。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工币励, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人珊拼。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓食呻,卻偏偏與公主長得像,于是被迫代替她去往敵國和親澎现。 傳聞我的和親對象是個殘疾皇子仅胞,可洞房花燭夜當晚...
    茶點故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)剑辫,斷路器饼问,智...
    卡卡羅2017閱讀 134,600評論 18 139
  • 用兩張圖告訴你,為什么你的 App 會卡頓? - Android - 掘金 Cover 有什么料揭斧? 從這篇文章中你...
    hw1212閱讀 12,693評論 2 59
  • 1.測試與軟件模型 軟件開發(fā)生命周期模型指的是軟件開發(fā)全過程莱革、活動和任務的結(jié)構性框架。軟件項目的開發(fā)包括:需求讹开、設...
    Mr希靈閱讀 21,938評論 7 278
  • 立秋過后盅视,夏日的余溫還在肆虐,即便是初入九月旦万,云火依舊闹击,路面上閃耀著扭曲的火花,但山林中成艘、小溪旁赏半、古城里贺归、長街...
    冷城CC閱讀 182評論 0 0
  • 今早剛起床的時候拂酣,就看到了宋仲基宋慧喬結(jié)婚的消息: 一姐說“童話終于實現(xiàn),這才是《太陽的后裔》劇終呀仲义!祝福我們的大...
    小懶君h閱讀 331評論 0 1