junit下不同路径下的配置文件

转:http://blog.youkuaiyun.com/rj042/article/details/7549462


Spring Junit 读取WEB-INF下的配置文件

标签: springjunitautowired测试bean框架
23926人阅读 评论(4) 收藏 举报
分类:

假设Spring配置文件为applicationContext.xml


一、Spring配置文件在类路径下面

在Spring的java应用程序中,一般我们的Spring的配置文件都是放在放在类路径下面(也即编译后会进入到classes目录下)。

以下是我的项目,因为是用maven管理的,所以配置文件都放在“src/main/resources”目录下



这时候,在代码中可以通过

  1. ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml");  
然后获取相应的bean。


如果代码想用Junit测试框架来测试,则Spring提供了对Junit支持,还可以使用注解的方式:

  1. @RunWith(SpringJUnit4ClassRunner.class)  
  2. @ContextConfiguration(locations={"classpath:applicationContext.xml"})  

只需要在相应的Test类前面加上此两个注解(第二个注解用来指明Spring的配置文件位置),就可以在Junit Test类使用中Spring提供的依赖注入功能。


二、Spring配置文件在WEB-INF下面

当然在做J2EE开发时,有些人习惯把Spring文件放在WEB-INF目录(虽然更多人习惯放在类路径下面)下面;或者有些Spring配置文件是放在类路径下面,而有些又放在

WEB-INF目录下面,如下图。


这时候,在代码中就不可以使用ClassPathXmlApplicationContext来加载配置文件了,而应使用FileSystemXmlApplicationContext。

  1. ApplicationContext applicationContext = new FileSystemXmlApplicationContext("src/main/webapp/WEB-INF/applicationContext.xml");  

然后获取相应的bean。


如果代码想用Junit测试框架来测试,则Spring提供了对Junit支持,还可以使用注解的方式:

  1. @RunWith(SpringJUnit4ClassRunner.class)  
  2. @ContextConfiguration(locations={"file:src/main/webapp/WEB-INF/applicationContext.xml"})   
只需要在相应的Test类前面加上此两个注解(第二个注解用来指明Spring的配置文件位置),就可以在Junit Test类使用中Spring提供的依赖注入功能。


下面是我的一个Spring管理下的Junit测试类:

  1. package com.sohu.group.service.external;  
  2.   
  3. import java.util.List;  
  4.   
  5. import org.junit.Test;  
  6. import org.junit.runner.RunWith;  
  7. import org.springframework.beans.factory.annotation.Autowired;  
  8. import org.springframework.test.context.ContextConfiguration;  
  9. import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;  
  10.   
  11. @RunWith(SpringJUnit4ClassRunner.class)  
  12. @ContextConfiguration({"file:src/main/webapp/WEB-INF/applicationContext.xml"})  
  13. public class SuFriendServiceImplOverRMITest {  
  14.   
  15.     @Autowired  
  16.     private SuFriendService suFriendService;  
  17.       
  18.     @Test  
  19.     public void getUserFollowerListTest(){  
  20.         List<String> list = suFriendService.getUserFollowerList("liug_talk@163.com");  
  21.         System.out.println("------"+list);  
  22.     }  
  23. }  




### 正确配置JUnit路径以确保测试顺利运行 为了确保JUnit能够正常工作并找到对应的测试文件,需要按照IDE的要求正确设置项目的结构以及相应的构建工具配置。当在IntelliJ IDEA中创建测试时,通过Quick Fixes可以方便地选择JUnit版本,并指定目标包的位置[^2]。 对于Maven项目而言,通常建议遵循标准目录布局,即源码位于`src/main/java/`下,而测试代码则放置于`src/test/java/`之中。如果采用Gradle作为构建工具,则默认情况下也会应用类似的约定。 具体到JUnit路径配置方面: - **确保测试位置正确**:测试类应当存放在`src/test/java/com/mark/entity`(假设主包名为`com.mark`)这样的路径之下。 - **验证pom.xml或build.gradle中的依赖项**:确认已经加入了JUnit库的支持。例如,在Maven环境中应包含如下片段: ```xml <!-- Maven pom.xml --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.13.2</version> <!-- 或者更新版本 --> <scope>test</scope> </dependency> ``` - **检查编译输出路径**:保证编译后的`.class`文件被正确放置到了`target/classes`(针对Maven)或者`build/classes/java/main`(对应Gradle)及其相应测试输出目录内。 另外,关于单元测试执行策略的选择也会影响最终效果。存在三种主要方式——孤立的单元测试、自顶向下的单元测试和自底向上的单元测试[^3]。不过这些更多涉及到设计层面而非单纯路径设定问题。 最后值得注意的是,除了上述措施外,还需关注CI/CD流水线脚本如Jenkinsfile内的相关指令是否恰当设置了环境变量与命令参数,从而保障整个流程顺畅无阻[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值