1、均需引入所需的包java
<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)加載配置文件<原始的手動加載方式>spring
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了。這裏列舉用註解的方式mybatis
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測試,有以下缺點:app
1)致使屢次Spring容器初始化問題
ide
2)須要使用硬編碼方式手工獲取Bean ,須要強制轉換
post
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屬性,就只能按名稱裝配了。