乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      dbunit

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

        本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多