<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Java蜘蛛人 歡迎大家

    歡迎大家 來到我的blog , 如果我身邊的朋友 有什么不懂可以直接來問我 我會細心的幫助你的. 如果網絡上的朋友有什么不懂的 可以加我Java蜘蛛人 QQ48187537
    posts - 54, comments - 192, trackbacks - 0, articles - 1

     

     利用spring的mock類進行單元測試:
    spring框架提供了大量測試的mock類,包括與jndi,porlet,web應用相關的mock類。尤其是web應用相關的mock類,可以大大提高web組件測試的方便性。

    打開spring的下載包的mock文件夾(路徑...mock\org\springframework\mock\web),就發覺有如下幾個文件:

    MockHttpServletRequest:是HttpServletRequest接口的mock實現,用來模擬客戶端的HTTP請求,很常用的一個類。

    MockHttpServletResponse:是HttpServletResponse接口的mock實現,用于模擬服務器對客戶端的響應。

    MockHttpSession:是對HttpSession接口的mock實現。

    DelegatingServletInputStream:是對ServletInputStream接口的mock實現。

    DelegatingServletOutputStream:ServletOutputStream的mock實現。需要攔截和分析服務器的輸出的流的內容,可以使用該類。

    其他的,例如MockFilterConfig,MockPageContext(可以測試預編譯的JSP),MockRequestDispatcher,MockServletConfig看名稱就知道大概是mock什么的。
    舉一個例子:
        MockHttpServletRequest request =  new MockHttpServletRequest("POST","/index.do");  
        request.addParameter("username","name");  
        request.addParameter("password","word"); 

    利用spring來進行集成測試
    1、AbstractSpringContextTests類[1],該類全部方法是protected的,通常不使用這個類,而使用它的子類們。

    2、AbstractDependencyInjectionSpringContextTests類[2]:繼承于類[1]:名字N長的。如果僅僅使用Spring依賴注入功能,可以讓測試用例繼承該類。

    3、AbstractTransactionalSpringContextTests類[3]:繼承于類[2],繼承該類的測試用例在spring管理的事務中進行,測試完后對數據庫的記錄不會造成任何影響。你對數據庫進行一些操作后,它會自動把數據庫回滾,這樣就保證了你的測試對于環境沒有任何影響

    4、AbstractTransactionalDataSourceSpringContextTests繼承于類[3],功能更強大,用于測試持久層組件,看其源代碼,有一行"protected JdbcTemplate jdbcTemplate;",提供了一個JdbcTemplate的變量,通過該對象可以直接操作數據庫。

    http://lighter.javaeye.com/blog/41733 還提供了兩個用spring來進行集成測試(對數據庫操作進行測試),業務測試(對業務層進行測試)的例子供下載。

    ***如何在你的TestCase Class里取得spring context (注意路徑問題)?***

    你的TestCase Class必須繼承的是上述四個AbstractXXXSpringContextTests中的其中一個,那么就必須實現下面這個方法來取得spring context

       protected abstract String[] getConfigLocations();

    例如:

     public String[] getConfigLocations() {
        String[] configLocations = { "applicationContext.xml","hibernate-context.xml" };
        return configLocations;
     }


    請 注意要加載的context xml file的路徑問題:上述的代碼是基于classpath,因此applicationContext.xml和hibernate- context.xml必須放在classpath里(方法一是把xml files放到WEB-INF/classes目錄下,另一種方法就是在project properties里把xml files的路徑加到classpath里)

    那么如果你一定要把context xml files放到WEB-INF目錄下,也是可以的,那么應該基于file(基于file的相對路徑是相對于project root folder),代碼如下:

     public String[] getConfigLocations() {
        String[] configLocations = { "file:WebContent/WEB-INF/applicationContext.xml"};
        return configLocations;
     }

    AbstractXXXSpringContextTests就會根據根據getConfigLocations方法返回的context xml位置的數組來加載并且對加載的Context提供緩存。 這是非常重要的,因為如果你在從事一個大項目時,啟動時間可能成為一個問題--這不是Spring自身的開銷,而是被Spring容器實例化的對象在實例 化自身時所需要的時間。例如,一個包括50-100個Hibernate映射文件的項目可能需要10-20秒的時間來加載上述的映射文件,如果在運行每個 測試fixture里的每個測試案例前都有這樣的開銷,將導致整個測試工作的延時,最終有可能(實際上很可能)降低效率。

    在某種極偶然的情況下,某個測試可能“弄臟”了配置場所,并要求重新加載--例如改變一個bean的定義或者一個應用對象的狀態--你可以調用 AbstractDependencyInjectionSpringContextTests 上的 setDirty() 方法來重新加載配置并在執行下一個測試案例前重建application context

     

    當類 AbstractDependencyInjectionSpringContextTests(及其子類)裝載你的Application Context時,你可以通過Setter方法來注入你想要的來自context的bean,而不需要顯式的調用applicationContext.getBean(XXX)。因為AbstractDependencyInjectionSpringContextTests會從getConfigLocations()方法指定的配置文件中幫你自動注入

    下面的例子就是通過setter方法來獲得context里的ProductManager bean:

    public class MyTest extends AbstractDependencyInjectionSpringContextTests {
        ProductManager productManager;

        public String[] getConfigLocations() {
            String[] configLocations = { "file:WebContent/WEB-INF/applicationContext.xml" };
            return configLocations;
        }

        public void testGetProduct() {
           assertEquals("tomson",productManager.getProductByName("tomson").getName());
        }
       

        //通過setter方法自動從context里注入productManager bean,而不用顯示調用applicationContext.getBean(XXX)
        public void setProductManager(ProductManager productManager) {
           this.productManager = productManager;
        }
    }

    但是如 果context里有多個bean都定義為一個類型(例如有多個bean都是ProductManager class類型的),那么對這些bean就無法通過setter方法來自動依賴注入(因為有多個bean同一個類型,不知要自動注入哪個)。在這種情況下 你需要顯示的調用applicationContext.getBean(XXX)來注入。如:

    public class MyTest extends AbstractDependencyInjectionSpringContextTests {
       ProductManager productManager;

       public String[] getConfigLocations() {
          String[] configLocations = { "file:WebContent/WEB-INF/applicationContext.xml" };
          return configLocations;
       }

       public void onSetUp() {
           productManager = (ProductManager) applicationContext.getBean("productManager");
       }

       public void testGetProduct() {
           assertEquals("tomson",productManager.getProductByName("tomson").getName());
       }
     
    }

    如果你的TestCase不使用依賴注入,只要不定義任何setters方法即可。或者你可以繼承 AbstractSpringContextTests --這個 org.springframework.test 包中的根類,而不是繼承AbstractDependencyInjectionSpringContextTests(及其子類)。這是因為AbstractSpringContextTests 只包括用來加載Spring Context的便利方法但沒有自動依賴注入的功能。

    Feedback

    # re: spring junit 測試  回復  更多評論   

    2009-06-04 17:02 by 無量字幕
    不錯

    # re: spring junit 測試  回復  更多評論   

    2009-06-05 17:32 by hellworld
    好厲害呀,鄭老師,你是IT蜘蛛俠!好屌??!

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 亚洲欧美综合精品成人导航| 亚洲无线电影官网| 国产精品亚洲综合天堂夜夜| 无码精品A∨在线观看免费| 4444亚洲国产成人精品| 免费视频成人手机在线观看网址| 亚洲欧洲日产国码无码网站| 国产免费人成视频尤勿视频| 亚洲桃色AV无码| 日本黄色动图免费在线观看| 亚洲国产日韩一区高清在线| 亚洲免费在线视频观看| 亚洲 欧洲 自拍 另类 校园| 精品免费国产一区二区| 黄色一级免费网站| 亚洲午夜无码久久久久| 99精品视频免费观看| 亚洲大片免费观看| 日本黄色免费观看| 成人A毛片免费观看网站| 久久精品亚洲综合专区| 日本高清在线免费| 国内成人精品亚洲日本语音| 亚洲综合国产精品第一页| 国产在线播放线91免费| 亚洲国产模特在线播放| 国产一区二区免费在线| 男女一边桶一边摸一边脱视频免费| 亚洲av午夜福利精品一区| 成人免费黄色网址| 国产亚洲漂亮白嫩美女在线| 精品国产综合成人亚洲区| 免费v片在线观看视频网站| 欧美激情综合亚洲一二区| 亚洲一区无码中文字幕| 久久国产色AV免费观看| 亚洲国产精品久久久久秋霞小| 久久亚洲色一区二区三区| 成年人免费的视频| 精品国产福利尤物免费| 91在线亚洲综合在线|