解決Spring boot 整合Junit遇到的坑
這是我在使用springboot整合Junit的時(shí)候遇到的坑
1.在pom.xml中添加junit環(huán)境的依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> </dependency>
2.在src/test/java下建立測(cè)試類
例:
@RunWith(value = SpringJUnit4ClassRunner.class) @SpringBootTest(classes={Demo.class}) // **注意:?jiǎn)?dòng)類為自己編寫的(這是個(gè)坑)** public class serviceTest { @Autowired private serviceImpl serviceimpl; @Test public void testAdd() { this.serviceimpl.add(); } }
3.自己編寫的啟動(dòng)類
@SpringBootApplication public class Demo { public static void main(String[] args) { SpringApplication springApplication = new SpringApplication(Demo.class); // 這個(gè)是關(guān)閉springboot啟動(dòng)時(shí)候的圖標(biāo)可以不設(shè)置 springApplication.setBannerMode(Banner.Mode.OFF); springApplication.run(args); } }
說明:
@RunWith:啟動(dòng)器 SpringJUnit4ClassRunner.class:讓 junit 與 spring 環(huán)境進(jìn)行整合
@SpringBootTest(classes={App.class})
1:當(dāng)前類為 springBoot 的測(cè)試類
2:加載 SpringBoot 啟動(dòng)類(啟動(dòng)類為自己編寫的啟動(dòng)類(這是個(gè)坑))。啟動(dòng)SpringBoot
SpringBoot 整合Junit測(cè)試注入Bean失敗
java.lang.IllegalStateException: Failed to load ApplicationContext
問題描述
我是在springboot整合測(cè)試的時(shí)候報(bào)錯(cuò)的。運(yùn)行就是報(bào)各種bean找不到。
版本:springboot-1.5.12 + junit4.12
這個(gè)問題卡了半天才解決。從網(wǎng)上搜了若干個(gè)博客都試了,基本上都沒有用。
什么加@WebAppConfiguration這個(gè)注解啊,加那個(gè)注解的,全沒用。
下面是我的測(cè)試類
11111
解決過程
我仔細(xì)觀察了一下啟動(dòng)類,因?yàn)檫@個(gè)@SpringBootTest我是設(shè)置的啟動(dòng)類的。才發(fā)現(xiàn)原來注入的這些找不到的bean,實(shí)際上都是啟動(dòng)類當(dāng)中使用依賴注入的對(duì)象。
以下是我的啟動(dòng)類
由此我推斷,雖然springboot自帶了掃描包(默認(rèn)掃描規(guī)則就是啟動(dòng)類以上的子包),但是他可能是遵循java的由上而下執(zhí)行代碼規(guī)律,因?yàn)樗吘故钦蠝y(cè)試,他和直接從啟動(dòng)類啟動(dòng)項(xiàng)目是不一樣的概念。在他要依賴注入這個(gè)對(duì)象的時(shí)候,而實(shí)際上這個(gè)對(duì)象并沒有放到容器當(dāng)中,這時(shí)候就會(huì)產(chǎn)生注入不成功。
最終在啟動(dòng)類添加了一個(gè)@ComponentScan(basePackages = {“com.xjgx”})掃描全包。成功解決!
在配置類上添加 @ComponentScan 注解。該注解默認(rèn)會(huì)掃描該類所在的包下所有的配置類,相當(dāng)于之前的 context:component-scan。
總結(jié)
springboot整合junit測(cè)試方法,實(shí)際上就這兩個(gè)注解就可以了。
@RunWith(SpringRunner.class) @SpringBootTest(classes = EhrApplication.class) public class EhrApplicationTest { @Autowired HealthExamReSerivice healthExamReSerivice; @Test public void contextLoads() { } }
假如啟動(dòng)類使用到了依賴注入對(duì)象,這個(gè)時(shí)候需要在啟動(dòng)類上添加掃描包。
@ComponentScan(basePackages = {"com.xjgx"})
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
基于Gradle搭建Spring?5.3.13-release源碼閱讀環(huán)境的詳細(xì)流程
這篇文章主要介紹了基于Gradle搭建Spring?5.3.13-release源碼閱讀環(huán)境,首先安裝jdk、gradle等一系列必要操作,本文通過實(shí)例代碼相結(jié)合給大家講解的非常詳細(xì),需要的朋友可以參考下2022-04-04JAVA 時(shí)間區(qū)間的字符串合法性驗(yàn)證
需要對(duì)獲得的諸如08:30-11:00這樣的字符串進(jìn)行合法性驗(yàn)證,判定表示的時(shí)間區(qū)間是否合法,以及對(duì)高峰期時(shí)間的區(qū)間是否在總的時(shí)間區(qū)間內(nèi)部進(jìn)行判斷。2013-03-03springboot3.x版本集成log4j遇到Logging?system?failed?to?initial
使用Springboot?3.x集成Log4j時(shí)可能會(huì)遇到版本沖突的問題,這通常可以通過檢查Maven依賴樹來識(shí)別,一旦發(fā)現(xiàn)沖突,將Log4j的版本統(tǒng)一更新到最新的兼容版本,例如2.21.1,即可解決問題,此方法有效解決了日志打印錯(cuò)誤,是處理類似問題的一個(gè)實(shí)用參考2024-09-09java實(shí)現(xiàn)表格tr拖動(dòng)的實(shí)例(分享)
下面小編就為大家分享一篇java實(shí)現(xiàn)表格tr拖動(dòng)的實(shí)例。具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2017-12-12