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