【Spring】Junit加載Spring容器作單元測試
> 引入相關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)注解的方式自動加載方式

1 @org.springframework.test.context.ContextConfiguration(locations={"file:WebRoot/WEB-INF/applicationContext.xml"}) 2 3 @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屬性,就只能按名稱裝配了。