解決@Test注解在Maven工程的Test.class類中無法使用的問題
@Test注解在Maven的Test.class類中無法使用
異常背景
在一個maven的web工程里, 我想寫一個簡單的測試類,于是就創(chuàng)建了一個類Test.class
在這個類里寫@Test注解方法, 發(fā)現(xiàn)無法導(dǎo)入包,手動import org.junit.Test;導(dǎo)入也是無效
異常信息
異常分析
我第一直覺是,pom.xml沒有配置坐標(biāo),看看發(fā)現(xiàn)配置了
再重新構(gòu)建下maven,發(fā)現(xiàn)還是不行
再重新創(chuàng)建一個其他測試類,發(fā)現(xiàn)可以正常使用
也就是說, 創(chuàng)建的測試類的名字不能使用Test , 可能原因我猜注解和類同名問題
解決方案
就是刪除這個Test.class測試類, 換一個名字就可以了
Maven工程找不到@Test
今天在IDEA下搭建maven進(jìn)行單元測試的時候,在非test文件下面,寫了一個測試類,發(fā)現(xiàn)@Test注解找不到,但是發(fā)現(xiàn)根路徑下是有junit的jar包的,比較郁悶,然后就去查看自己的代碼,發(fā)現(xiàn)在maven依賴中,junit的scope是test,如圖一所示,果斷將測試類放在test文件下,問題迎刃而解。
當(dāng)然,如果把scope改為compile,測試類不一定要放在test文件下,放在main文件下也可以。
圖一
進(jìn)一步觀察可以發(fā)現(xiàn),問題出現(xiàn)在maven依賴范圍內(nèi),查閱資料發(fā)現(xiàn)
maven的scope范圍如下
1.test范圍指的是測試范圍有效,在編譯和打包時都不會使用這個依賴
2.compile范圍指的是編譯范圍有效,在編譯和打包時都會講依賴存儲進(jìn)去
3.provided依賴:在編譯和測試范圍有效,最后生成war時不會加入,例:servlet-api,如圖二所示,因為servlet-api,tomcat等在web服務(wù)器已經(jīng)存在,如果在打包會沖突
圖二
4.runtime在運行時依賴,在編譯的時候不依賴
默認(rèn)的依賴范圍是compile
由此進(jìn)一步引申出test的傳遞依賴性,參考他人博客,如下:
依賴的傳遞
作用域是test的包不會傳遞到引用這個項目的其它項目,但如果不是test會傳遞依賴到其它項目。
如:項目A中有一個依賴包junit4.10,它的作用域是test
現(xiàn)在有一個項目B,引用項目A,如果項目B要使用junit4.10就必須自己重新定義依賴關(guān)系?!疽驗椴粫鬟f依賴,所以不會從項目A中得到】
但:如果作用域是其它的,不是test
那么項目B可以直接使用不用自己再定義一個依賴關(guān)系?!疽驗闀捻椖緼中自動傳遞依賴,而得到】
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringCloud中的路由網(wǎng)關(guān)鑒權(quán)熔斷詳解
這篇文章主要介紹了SpringCloud中的路由網(wǎng)關(guān)鑒權(quán)熔斷詳解,Hystrix是一個用于處理分布式系統(tǒng)的延遲和容錯的開源庫,在分布式系統(tǒng)里,許多依賴不可避免的會調(diào)用失敗,比如超時、異常等,需要的朋友可以參考下2024-01-01使用Rhino讓java執(zhí)行javascript的方法實例
這篇文章主要介紹了java使用Rhino執(zhí)行javascript的方法,Rhino由Mozilla開發(fā),是 JavaScript 一種基于Java的實現(xiàn)2013-12-12關(guān)于@Autowired注入依賴失敗的問題及解決
這篇文章主要介紹了關(guān)于@Autowired注入依賴失敗的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08Spring Boot 部署過程解析(jar or war)
這篇文章主要介紹了Spring Boot 部署過程解析(jar or war),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-09-09