【概念】
dbunit是一個基于junit擴展的數(shù)據(jù)庫測試框架。它提供了大量的類對與數(shù)據(jù)庫相關(guān)的操作進行了抽象和封裝,雖然在80%的情況,你只需使用它極少的api。它通過使用用戶自定義的數(shù)據(jù)集以及相關(guān)操作使數(shù)據(jù)庫處于一種可知的狀態(tài),從而使得測試自動化、可重復和相對獨立。雖然不用dbunit也可以達到這種目的,但是我們必須為此付出代價(編寫大量代碼,測試及維護),既然有了這么優(yōu)秀的開源框架,我們又何必再造輪子。
DbUnit是為數(shù)據(jù)庫驅(qū)動的項目提供的一個對JUnit 的擴展,除了提供一些常用功能,它可以將你的數(shù)據(jù)庫置于一個測試輪回之間的狀態(tài)。
【簡介】
為依賴于其他外部系統(tǒng)(如數(shù)據(jù)庫或其他接口)的代碼編寫單元測試是一件很困難的工作。在這種情況下,有效的單元必須隔離測試對象和外部依賴,以便管理測試對象的狀態(tài)和行為。
使用mock object對象,是隔離外部依賴的一個有效方法。如果我們的測試對象是依賴于DAO的代碼,mock object技術(shù)很方便。但如果測試對象變成了DAO本身,又如何進行單元測試呢?
開源的DbUnit項目,為以上的問題提供了一個相當優(yōu)雅的解決方案。使用DbUnit,開發(fā)人員可以控制測試數(shù)據(jù)庫的狀態(tài)。進行一個DAO單元測試之前,DbUnit為數(shù)據(jù)庫準備好初始化數(shù)據(jù);而在測試結(jié)束時,DbUnit會把數(shù)據(jù)庫狀態(tài)恢復到測試前的狀態(tài)。
【原理】
dbunit的與單元測試相關(guān)的兩個最重要的核心是org.dbunit.database.IDatabaseConnection 和 org.dbunit.dataset.IDataSet ,前者是產(chǎn)品代碼使用的數(shù)據(jù)庫連接的一個簡單的封裝,后者是對單元測試人員自定義的數(shù)據(jù)集(通常以xml文件的形式存在,且xml文件的格式也有好幾種)的封裝。
還有一個很重要的咚咚就是org.dbunit.operation.DatabaseOperation,該類是一個抽象類代表了對數(shù)據(jù)庫的操作,例如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)