您好,登錄后才能下訂單哦!
此博客解決了什么問題:
解決測試的時候代碼冗余的問題,解決了測試工程師的編碼能力可能沒有開發工程師編碼能力的問題,解決了junit單元測試和spring注解相結合!
測試類代碼:(只給大家展示測試類的代碼)
public class AccountServiceTest { @Test public void testFindAll(){ //1.獲取容器 ApplicationContext ac=new ClassPathXmlApplicationContext("bean.xml"); //2.得到業務層對象 IAccountService as =ac.getBean("accountService",IAccountService.class); //3.執行方法 List<Account> accounts=as.findAllAccount(); for(Account account:accounts){ System.out.println(account); } } @Test public void testFindSave(){ Account account=new Account(); account.setMoney(20000f); account.setName("test"); //1.獲取容器 ApplicationContext ac=new ClassPathXmlApplicationContext("bean.xml"); //2.得到業務層對象 IAccountService as =ac.getBean("accountService",IAccountService.class); as.saveAccount(account); } @Test public void testFindUpdate(){ Account account=new Account(); //1.獲取容器 ApplicationContext ac=new ClassPathXmlApplicationContext("bean.xml"); //2.得到業務層對象 IAccountService as =ac.getBean("accountService",IAccountService.class); account=as.findAccountById(4); account.setMoney(40000f); as.updateAccount(account); } }
以上的代碼都有公共的地方:
//1.獲取容器 ApplicationContext ac=new ClassPathXmlApplicationContext("bean.xml"); //2.得到業務層對象 IAccountService as =ac.getBean("accountService",IAccountService.class);
此時為了減少代碼的冗余我們完全可以將其抽離出來,如下:
private ApplicationContext ac; private IAccountService as; @Before public void init(){ //1.獲取容器 ac=new ClassPathXmlApplicationContext("bean.xml"); //2.得到業務層對象 as =ac.getBean("accountService",IAccountService.class); } @Test public void testFindAll(){ //3.執行方法 List<Account> accounts=as.findAllAccount(); for(Account account:accounts){ System.out.println(account); } } @Test public void testFindSave(){ Account account=new Account(); account.setMoney(20000f); account.setName("test"); as.saveAccount(account); } @Test public void testFindUpdate(){ Account account=new Account(); account=as.findAccountById(4); account.setMoney(40000f); as.updateAccount(account); }
上面的代碼似乎解決了我們的問題,但是我們忽略了一個問題,就是說在軟件開發的過程中,這是兩個角色,開發代碼的是軟件開發工程師,而這個測試的為軟件測試工程師,對于測試人員只管方法能不能執行,性能怎么樣,上面抽離出的代碼測試人員不一定會寫!
private ApplicationContext ac; private IAccountService as; @Before public void init(){ //1.獲取容器 ac=new ClassPathXmlApplicationContext("bean.xml"); //2.得到業務層對象 as =ac.getBean("accountService",IAccountService.class); }
分析:
首先我們先明確三點:
1.一般應用程序的入口都有main方法,但是在junit單元測試中,沒有main方法也能執行,junit集成了一個main方法,該方法就會判斷當前測試類中 是否有@test注解,然后讓帶著Test注解的類執行。
2、junit不會管我們是否采用spring框架,在執行測試方法時,junit根本不知道我們是不是使用了spring框架,所以也就不會為我們讀取配置文件/配置類創建spring核心容器
3.當測試方法執行時,沒有Ioc容器,就算寫了Autowired注解,也無法實現注入
綜上所述:按照我們之前的Autowried注入已經不好使了!接下看解決辦法:
1.導入spring整合junit的jar(坐標)
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>5.0.2.RELEASE</version> </dependency>
2.使用junit提供的一個注解把原有的main方法替換了,替換成spring提供的,
這個注解是@RunWith,然后網上有這樣的解釋,我覺得比較貼切:
@RunWith就是一個運行器
@RunWith(JUnit4.class)就是指用JUnit4來運行
@RunWith(SpringJUnit4ClassRunner.class),讓測試運行于Spring測試環境,以便在測試開始的時候自動創建Spring的應用上下文
注解了@RunWith就可以直接使用spring容器,直接使用@Test注解,不用啟動spring容器
@RunWith(Suite.class)的話就是一套測試集合
3.告知spring的運行器,spring創建是基于xml還是注解的,并說明位置
這個注解就是:@ContextConfiguration
locations:指定xml文件的位置,加上classpath關鍵字,表示在類路徑下
classes: 指定注解類所在地位置
當我們使用spring 5.x版本的時候,要求junit的jar必須是4.12及以上
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(classes = SpringConfiguration.class) public class AccountServiceTest { @Autowired private IAccountService accountService; @Test public void testFindAll() { //3.執行方法 List<Account> accounts = accountService.findAllAccount(); for(Account account : accounts){ System.out.println(account); } } @Test public void testSave() { Account account = new Account(); account.setName("test anno"); account.setMoney(12345f); //3.執行方法 accountService.saveAccount(account); } @Test public void testUpdate() { //3.執行方法 Account account = accountService.findAccountById(4); account.setMoney(23456f); accountService.updateAccount(account); } }
補充知識:idea Could not autowire. No beans of 'XXXX' type found.
如下圖:在使用@Autowired注解的時候,提示找不到bean類型,查找了半天錯誤,發現這就不是錯誤,因為它根本不會影響程序的運行! 此時我以為是我的Service層注解沒寫,可是明明寫了!看下面的解決辦法!
解決辦法:
點擊文件–setting–Editor–Inspections–spring–Warning–Apply–OK
以上這篇java spring整合junit操作(有詳細的分析過程)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。