此文收集一些平時使用單元測試碰到的問題和解決辦法,供你們參考。html
Microsoft UnitTestFramework | 若是須要元素的順序一致,可使用CollectionAssert.AreEqual;若是不須要考慮順序,可使用CollectionAssert.AreEquivalent。(有的地方說MSTest的Assert.AreEqual支持集合類型比較,我測試過,忽悠人的) |
nUnit | 同上 |
xUnit | xUnit的Assert.Equal(c1, c2)能夠支持集合類型比較,c1和c2的元素順序必須一致 |
Microsoft UnitTestFramework和nUnit的用法很是相似,而xUnit因爲吸收了nUnit的設計上的經驗,用法更加簡潔。下面是周公寫的兩篇文章,nUnit和xUnit介紹的很是詳細,你們能夠閱讀一下:git
單元測試的目標是一次只驗證一個方法,小步的前進,細粒度的測試,可是假如某個方法依賴於其餘一些難以操控的東東,好比說網絡鏈接、數據庫鏈接、系統時間、或者是Servlet容器,那麼咱們該怎麼辦呢?要是你的測試依賴於系統的其餘部分,甚至是系統的多個其餘部分呢?在這種狀況下,假若不當心,你最終可能會發現本身幾乎初始化了系統的每一個組件,而這只是爲了給一個測試創造足夠的運行環境讓它們能夠運行起來。忙乎了大半天,看上去咱們好像有點違背了測試的初衷了。這樣不只僅消耗時間,還給測試過程引入了大量的耦合因素,好比說,可能有人興致沖沖地改變了一個接口或者數據庫的一張表,忽然,你那卑微的單元測試的神祕的掛掉了。在這種狀況發生幾回以後,即便是最有耐心的開發者也會泄氣,甚至最終放棄全部的測試,那樣的話後果就不能想像了。github
再讓咱們看一個更加具體的狀況:在實際的面向對象軟件設計中,咱們常常會碰到這樣的狀況,咱們在對現實對象進行構建以後,對象之間是經過一系列的接口來實現。這在面向對象設計裏是最天然不過的事情了,可是隨着軟件測試需求的發展,這會產生一些小問題。舉個例子,用戶A如今拿到一個用戶B提供的接口,他根據這個接口實現了本身的需求,可是用戶A編譯本身的代碼後,想簡單模擬測試一下,怎麼辦呢?這點也是很現實的一個問題。咱們是否能夠針對這個接口來簡單實現一個代理類,來測試模擬,指望代碼生成本身的結果呢?幸運的是,有一種測試模式能夠幫助咱們:mock對象。Mock對象也就是真實對象在調試期的替代品。web
關於何時須要Mock對象,Tim Mackinnon給咱們了一些建議:sql
.NET Mock Framework有哪些,能夠看看下面幾個網頁:數據庫
關於Mock框架的實現方式,大概有兩種:基於動態代理實現;基於編譯時靜態織入實現。各個框架的用法看一下介紹很快就能夠掌握了,關鍵是如何使用各類mock技術,存在的爭論主要有下面幾個:編程
實際狀況中,我會根據項目實際狀況來選型。考慮的因素主要有:安全
測試驅動數據庫開發,也稱爲TDDD(Test-Driven Database Development),是把TDD的理念運用到數據庫開發的過程當中,經過數據庫測試來定義數據庫的行爲,如同經過測試定義應用程序代碼邏輯同樣,來保證數據庫重構過程當中的質量。網絡
使用 TDDD 的優勢包括:app
推薦感興趣的朋友看看伍斌老師翻譯《測試驅動數據庫開發——Test-Driven Database Development: Unlocking Agility》這本書:
目錄結構:http://my.safaribooksonline.com/book/databases/database-design/9780132776486
伍斌老師的譯者序:讓數據庫應用開發再也不裸奔——Test-Driven Database Development譯者序
樣章試讀:http://ptgmedia.pearsoncmg.com/images/9780321784124/samplepages/032178412X.pdf
原做者Max Guernsey的PPT:http://www.maxthe3rd.com/test-driven-database-development/TDD-Database.pdf
因爲這塊研究不深,暫時列舉一些數據庫單元測試框架,將來若是研究更加深刻了,再專門寫文章介紹。
數據庫單元測試的框架: