SpringJUnit4ClassRunner、ModelMap

本文深入探讨了SpringJUnit4ClassRunner在Spring容器环境下的应用,解析如何通过它实现Service、Dao、Action等组件的测试。同时,详细介绍了ModelMap对象的作用及使用方法,包括如何向结果页面传递数据,以及如何设置页面跳转的URL地址。
 

 


@RunWith(SpringJUnit4ClassRunner.class)

/*
这种写法是为了让测试在Spring容器环境下执行。
Spring的容器环境是啥呢?
比如常见的 Service  Dao  Action , 这些个东西,都在Spring容器里,junit需要将他们拿到,并且使用来测试。
*/

 

 

ModelMap的作用:
/*
ModelMap对象主要用于传递控制方法处理数据到结果页面,也就是说我们把结果页面上需要的数据放到ModelMap对象中即可

具体存放数据的方法如下:
addAttribute(String key,object value);

页面获取数据的方法如下:
${key}

modelmap本身不能设置页面跳转的url地址别名或者物理跳转地址,那么我们可以通过控制器方法的返回值来设置跳转url地址别名或者物理跳转地址。 

跳转url地址:return:url;

*/

 

### 使用JUnit 5 替代 JUnit 4 中的 `SpringJUnit4ClassRunner` 在 Spring 和 JUnit 的集成中,`SpringJUnit4ClassRunner` 是用于支持基于 JUnit 4 的测试框架的核心组件之一。然而,在迁移到 JUnit 5 后,由于其架构的变化以及命名空间的不同,需要采用新的方式实现相同的功能。 #### 迁移至 JUnit 5 在 JUnit 5 中,不再使用 `@RunWith` 注解来指定自定义运行器。取而代之的是通过扩展机制或者内置的支持完成类似的配置工作。对于 Spring 测试环境下的迁移,可以使用以下方法: 1. **引入依赖** 需要确保项目中已经包含了必要的 JUnit 5 和 Spring 支持库。以下是 Maven 或 Gradle 的依赖项示例: #### Maven ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <!-- 如果未包含 JUnit Jupiter --> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter-engine</artifactId> <version>5.x.x</version> <scope>test</scope> </dependency> ``` 2. **替换注解** 在 JUnit 5 下,推荐使用 `@ExtendWith` 来代替旧版中的 `@RunWith`。具体来说,可以用如下形式替代原有的 `@RunWith(SpringJUnit4ClassRunner.class)`: ```java import org.junit.jupiter.api.extension.ExtendWith; import org.springframework.test.context.junit.jupiter.SpringExtension; @ExtendWith(SpringExtension.class) public class MyTest { // Test methods here... } ``` 3. **其他常用注解调整** 对于一些常见的 Spring 测试场景,例如加载上下文或模拟 MVC 请求等操作,仍然保持一致的行为模式,只需注意适配新版本 API 变更即可。比如构建 MockMvc 实例时仍需配合 `WebApplicationContext` 完成初始化过程[^2]。 4. **参数化测试转换** 若涉及复杂逻辑验证,则可能需要用到参数驱动型单元检验手段。此时按照官方文档指导执行相应改造步骤即可满足需求[^4]: - 更改原有 runner 类型; - 修改构造函数签名接受外部传入数据源; - 更新静态工厂方法提供样本集合作为输入依据等等。 以上即完成了从传统意义上依靠特定 Runner 执行流程向现代化模块化设计理念转变的过程概述。 ```java // 示例代码片段展示如何结合两者功能特性编写实际业务案例 import static org.mockito.Mockito.*; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.params.ParameterizedTest; import org.junit.jupiter.params.provider.CsvSource; import org.mockito.InjectMocks; import org.mockito.Mock; import org.mockito.MockitoAnnotations; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.autoconfigure.web.servlet.WebMvcTest; import org.springframework.http.MediaType; import org.springframework.test.web.servlet.MockMvc; import org.springframework.test.web.servlet.request.MockMvcRequestBuilders; import org.springframework.test.web.servlet.result.MockMvcResultMatchers; @WebMvcTest(MyController.class) public class ControllerParametricTests { private MockMvc mockMvc; @BeforeEach void setup() { MockitoAnnotations.openMocks(this); } @ParameterizedTest(name = "{index} => input={0}, expectedOutput={1}") @CsvSource({ "'GET /api/resource', 'OK'", "'POST /api/other-resource', 'Created'" }) public void testEndpointResponses(String requestDetails, String expectedResult){ try{ this.mockMvc.perform(MockMvcRequestBuilders.get("/some-path")) .andExpect(MockMvcResultMatchers.status().isOk()); }catch(Exception e){ /* Handle exception */ }; } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值