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)

相關詞條

相關搜尋

熱門詞條

聯絡我們