【Spring】Junit加載Spring容器作單元測試(整理)


原文地址:https://www.cnblogs.com/swugogo/p/5908435.html

閱讀目錄

> 引入相關Jar包

一、均需引入所需的包

<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>3.8.1</version>
    <scope>test</scope>
</dependency>

<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-test</artifactId>
    <version>3.2.10.RELEASE</version>
</dependency>

>配置文件加載方式

(a)加載配置文件<原始的手動加載方式>

ApplicationContext context = new FileSystemXmlApplicationContext("WebRoot/WEB-INF/applicationContext.xml");
new ClassPathXmlApplicationContext("applicationContext.xml");// 從classpath中加載
new FileSystemXmlApplicationContext("classpath:地址");// 沒有classpath表示當前目錄 

(b)注解的方式自動加載方式

 @org.springframework.test.context.ContextConfiguration(locations={"file:WebRoot/WEB-INF/applicationContext.xml"})
 
 @org.springframework.test.context.ContextConfiguration(locations={"classpath:applicationContext.xml"}) 
 @RunWith(SpringJUnit4ClassRunner.class)  //使用junit4進行測試  
    @ContextConfiguration   
    ({"/spring/app*.xml","/spring/service/app*.xml"}) //加載配置文件  
      
    //------------如果加入以下代碼,所有繼承該類的測試類都會遵循該配置,也可以不加,在測試類的方法上///控制事務,參見下一個實例  
    //這個非常關鍵,如果不加入這個注解配置,事務控制就會完全失效!  
    //@Transactional  
    //這里的事務關聯到配置文件中的事務控制器(transactionManager = "transactionManager"),同時//指定自動回滾(defaultRollback = true)。這樣做操作的數據才不會污染數據庫!  
    //@TransactionConfiguration(transactionManager = "transactionManager", defaultRollback = true)  
    //------------  
    public class BaseJunit4Test {  
    }  

>原始的用法

測試類中要設置加載哪些Spring的配置(我這里是“/config/application*.xml”),然后就可以注入容器中的bean了。這里列舉用注解的方式

package com.nicchagil.mybatis3spring3intg.junit;

import java.util.List;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import com.nicchagil.mybatis3spring3intg.bean.User;
import com.nicchagil.mybatis3spring3intg.service.UserService;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration({"/config/application*.xml"})
public class JunitTest {
    
    @Autowired
    private UserService userService;
    
    @Test
    public void c1() {
        List<User> userList = userService.query(new User());
        System.out.println(userList);
    }

}

在具體的測試類中,采用手動加載配置文件的方式進行JUnit測試,有如下缺點

1)導致多次Spring容器初始化問題

2)需要使用硬編碼方式手工獲取Bean ,需要強制轉換

3)數據庫現場容易遭受破壞(理想的狀態:自動回滾對數據庫的操作,保證數據庫的現場不被破壞,因此重復測試不會發生問題)

4)不方便對數據操作正確性進行檢查(理想狀態:過jdbcTemplate在同一事務中訪問數據庫,查詢數據的變化,驗證操作的正確性)

 

> 常見的用法

常用的方式是將加載配置的部分公用出來:

package com.nicchagil.mybatis3spring3intg.junit;

import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration({"/config/application*.xml"})
public class BaseJunit {
    
}

然后需要的各個測試類繼承公用類:

package com.nicchagil.mybatis3spring3intg.junit;

import java.util.List;

import org.junit.Test;
import org.springframework.beans.factory.annotation.Autowired;

import com.nicchagil.mybatis3spring3intg.bean.User;
import com.nicchagil.mybatis3spring3intg.service.UserService;

public class UserServiceTest extends BaseJunit {
    
    @Autowired
    private UserService userService;
  @Resource //自動注入,默認按名稱  
  private IBaseDao baseDao; 

  @Test //標明是測試方法  
  @Transactional //標明此方法需使用事務  
  @Rollback(false) //標明使用完此方法后事務不回滾,true時為回滾  
  public void c1() { 
    List<User> userList = userService.query(new User()); 
    System.out.println(userList); 
  } 
}
//復習:@Autowired & @Resource 的區別
//@Autowired注解是按類型裝配依賴對象,默認情況下它要求依賴對象必須存在,如果允許null值,可以設置它required屬性為false。如果我們想使用按名稱裝配,可以結合@Qualifier注解一起使用。如下: 
//    @Autowired  @Qualifier("personDaoBean") 
//    private PersonDao  personDao; 

//@Resource注解和@Autowired一樣,也可以標注在字段或屬性的setter方法上,但它默認按名稱裝配。名稱可以通過@Resource的name屬性指定,如果沒有指定name屬性,當注解標注在字段上,即默認取字段的名稱作為bean名稱尋找依賴對象,當注解標注在屬性的setter方法上,即默認取屬性名作為bean名稱尋找依賴對象。 
//    @Resource(name=“personDaoBean”) 
//    private PersonDao  personDao;//用於字段上 

//注意:如果沒有指定name屬性,並且按照默認的名稱仍然找不到依賴對象時, @Resource注解會回退到按類型裝配。但一旦指定了name屬性,就只能按名稱裝配了。 

 

 

舉例:

工具類:RestClientUtil.java
package com.kszsa.common.rest;

import org.springframework.stereotype.Component;
import org.springframework.web.client.RestTemplate;

import java.util.Map;

@Component
public class RestClientUtil {
    /**
     * 調用遠程Rest接口
     * @param url
     * @param classType
     * @param params
     * @param <T>
     * @return
     */
    public <T> T get(String url, Class<T> classType, Map<String,Object> params){
        RestTemplate restTemplate = new RestTemplate();
        return restTemplate.getForObject(url, classType, params);
    }
}

測試類

RestClientUtilTest.java
package com.kszsa.common.rest;

import com.alibaba.fastjson.JSONObject;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import java.util.HashMap;
import java.util.Map;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath*:/*.xml"})
public class RestClientUtilTest {
    @Autowired
    private RestClientUtil restClientUtil;

    @Test
    public void get(){
        String url = "http://localhost:8080/ssht/user/get?id={id}";
        Map<String, Object> map = new HashMap<String, Object>();
        map.put("id",2);
        JSONObject jsonObject = restClientUtil.get(url, JSONObject.class, map);
        System.out.println(jsonObject);
    }


}

 源碼地址:https://gitee.com/kszsa/ssht.git


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM