dbunit走起~~~轉自百度百科

Dbunit

【概念】
dbunit是一個基於junit擴展的數據庫測試框架。它提供了大量的類對與數據庫相關的操作進行了抽象和封裝,雖然在80%的情況,你只需使用它極少的api。它通過使用用戶自定義的數據集以及相關操作使數據庫處於一種可知的狀態,從而使得測試自動化、可重複和相對獨立。雖然不用dbunit也可以達到這種目的,但是我們必須爲此付出代價(編寫大量代碼,測試及維護),既然有了這麼優秀的開源框架,我們又何必再造輪子。
       DbUnit是爲數據庫驅動的項目提供的一個對JUnit 的擴展,除了提供一些常用功能,它可以將你的數據庫置於一個測試輪迴之間的狀態。
【簡介】
       爲依賴於其他外部系統(如數據庫或其他接口)的代碼編寫單元測試是一件很困難的工作。在這種情況下,有效的單元必須隔離測試對象和外部依賴,以便管理測試對象的狀態和行爲。
       使用mock object對象,是隔離外部依賴的一個有效方法。如果我們的測試對象是依賴於DAO的代碼,mock object技術很方便。但如果測試對象變成了DAO本身,又如何進行單元測試呢?
       開源的DbUnit項目,爲以上的問題提供了一個相當優雅的解決方案。使用DbUnit,開發人員可以控制測試數據庫的狀態。進行一個DAO單元測試之前,DbUnit爲數據庫準備好初始化數據;而在測試結束時,DbUnit會把數據庫狀態恢復到測試前的狀態。
【原理】
dbunit的與單元測試相關的兩個最重要的核心是org.dbunit.database.IDatabaseConnection 和 org.dbunit.dataset.IDataSet ,前者是產品代碼使用的數據庫連接的一個簡單的封裝,後者是對單元測試人員自定義的數據集(通常以xml文件的形式存在,且xml文件的格式也有好幾種)的封裝。
還有一個很重要的咚咚就是org.dbunit.operation.DatabaseOperation,該類是一個抽象類代表了對數據庫的操作,例如CUD以及其組合等, 它採用了退化的工廠模式,可直接通過它獲取其具體的子類(代表具體的某種操作)如下:
DatabaseOperation.UPDATE
DatabaseOperation.DELETE
DatabaseOperation.DELETE_ALL
DatabaseOperation.TRUNCATE
DatabaseOperation.REFRESH
DatabaseOperation.CLEAN_INSERT
DatabaseOperation.NONE
工作流程如下:
1)testcase.setup--->testcase.getConnection-->getDataSet----->operation.execute(
通常DatabaseOperation.CLEAN_INSERT)
2)testcase.testSomeMethod---->dao.someMethod
3)testcase.teardown---->operation.execute(
通常DatabaseOperation.DELETE_ALL或者DatabaseOperation.NONE)
發佈了28 篇原創文章 · 獲贊 25 · 訪問量 22萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章