<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 32,comments - 75,trackbacks - 0
    前一陣子在看關(guān)于TestNG的東西,不小心看到Cedric的一篇blog(http://beust.com/weblog/archives/000171.html),突然得到很多啟發(fā)。
    這篇blog講的是方法的依賴,然而最讓我感興趣的是下面的回復(fù)。

    I don't buy your arguments. It just looks to me as though you're overlooking the "unit" aspect of JUnit.

    The premise of JUnit is that a TestCase is a collection of independant tests. The setUp method MUST therefore be called before each test because that is how the tests are made independant : its responsibility is to setup up the environement.
    That is also why you will get 20 failures : each test is independant, the only relationship between them is that they use the same setUp method (or, as almost everybody using JUnit does, they refer to the same Class to test).

    看到這,我突然想到有本單元測試的書,一開始就告訴我們,單元測試是獨(dú)立的,沒有順序,不互相依賴,從這個理論看,Junit的做法是絕對正確的,而TestNG的dependent完全是沒有必要的。

    然而我懷疑的是,我們是否能夠做到真的獨(dú)立的測試每個方法?
    最簡單的例子
    方法A調(diào)用了方法B,為了讓方法A不依賴于B的正確性,我們通常的做法是什么,Mock。沒錯,我們會做一個Mock B,然后可以告訴自己,我們可以獨(dú)立的測試A,因?yàn)槲覀冏隽藗€假的Mock B,而Mock  B是絕對正確的,所以在測試A的時候我們不用考慮B了。
    然而考慮一下如果B做了下面的事
    1。往數(shù)據(jù)庫做了操作(增刪查改)
    2。修改了某配置文件
    3。往Jms發(fā)送了某消息
    當(dāng)然還有很多,這些事你能Mock的了嗎?ok,總會有牛人把這些都能Mock了,實(shí)現(xiàn)了,然而你要回答我一個問題,如果你的Mock把這些事都做了,那他和真實(shí)的方法B又有什么區(qū)別?(補(bǔ)充一下,并不是否定Mock的作用,我認(rèn)為Mock最大的作用在于模擬正常情況下無法或者很難出現(xiàn)的情況,特別是拋出某個異常)

    個人認(rèn)為,在現(xiàn)在的配置環(huán)境越來越復(fù)雜的情況下,方法正在喪失他的獨(dú)立性,要想獨(dú)立的測試A或者B已經(jīng)是越來越難的一件事了,真正對立的方法只有在Sun的API那里才有(沒有貶低的意思),只有輸入和輸出。

    在傳統(tǒng)的單元測試?yán)碚撓旅妫覀冇刑嗟碾y題,數(shù)據(jù)庫(現(xiàn)在有些工具,例如DBunit,但我看解決不了所有的問題),MVC中的Action,顯示層,我們突然發(fā)現(xiàn)對每一個類型的方法,我們都要使用特定的工具去解決他們的測試的問題。

    TestNG并不能解決所有的問題,但我想是一個正確的方向,這絕不僅僅是框架之爭,而是我們到底該如何進(jìn)行我們的單元測試。我極贊同下面的話:
    The problem is that the core of JUnit has not changed with the changes in it the way that developers use it.

    下面基本屬于本人的胡思亂想:
    我們開始造馬車,發(fā)現(xiàn)每個最小的單位都是有功能的,比如輪子,馬。然后我們造汽車,我們的最小的單位變成了某個螺絲釘,或者是一個齒輪,我想說的是一個螺絲釘離開了發(fā)動機(jī),它什么都做不了。

    posted on 2005-12-19 11:20 fanta 閱讀(2916) 評論(1)  編輯  收藏 所屬分類: Java

    FeedBack:
    # re: 單元測試,TestNG,Junit[未登錄]
    2011-05-27 16:03 | XXX
    lz沒寫過mock  回復(fù)  更多評論
      
    主站蜘蛛池模板: 18亚洲男同志videos网站| 日本一道一区二区免费看| 国产亚洲精品无码拍拍拍色欲| 亚洲国产一区二区三区在线观看 | 国产精品免费观看久久| 亚洲天堂在线播放| 久久w5ww成w人免费| 久久久久久亚洲精品成人| 91久久成人免费| 亚洲人成影院在线高清| 色婷婷7777免费视频在线观看| 亚洲天堂2016| 日本一区免费电影| 污网站在线观看免费| 亚洲中文字幕久久精品无码APP| 久久久WWW免费人成精品| 国产精一品亚洲二区在线播放| 99久久精品免费精品国产| 亚洲成人高清在线观看| 在线免费视频一区| 青青免费在线视频| 国产亚洲av片在线观看播放| 在线成人爽a毛片免费软件| 亚洲中文字幕日本无线码| 又大又黄又粗又爽的免费视频 | 国产午夜无码精品免费看动漫| 亚洲国产成人久久综合一 | 亚洲色一区二区三区四区| 在线永久免费观看黄网站| 一级特黄a免费大片| 久久亚洲伊人中字综合精品| 一个人看www在线高清免费看| 免费夜色污私人影院网站| 亚洲AV无码一区二区三区DV| AA免费观看的1000部电影| 久香草视频在线观看免费| 日木av无码专区亚洲av毛片| 日本免费中文字幕在线看| 嫩草成人永久免费观看| 亚洲一区二区无码偷拍| 亚洲情综合五月天|