Spring学习-15:Spring整合Junit

本文介绍如何在Spring项目中集成Junit进行单元测试。通过添加依赖、使用注解,可以轻松实现服务层的测试,提高开发效率。

Spring开发中集成Junit测试。

1、程序中有Junit环境。

右击项目,buildpath,add Libraries:

next,Junit4,finish。

2、导入jar包:Spring与Junit整合的jar包 spring-test-3.2.0.RELEASE.jar

这样功能就添加完成了,下面我们来测试一下这与之前的@Test方式有什么不同:

编写测试类:

package com.js.Test;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import com.js.service.UserService;

/**
 * 引入了jar包之后,就可以使用一些注解了
 * @RunWith(SpringJUnit4ClassRunner.class)写法固定
 * @author js
 *
 */
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations="classpath:applicationContext.xml")
public class SpringTest {
	@Autowired
	private UserService userService;
	
	@Test
	public void demo1(){
		userService.sayHello();
	}
}
运行测试:

测试类中直接使用注解加载配置文件、注入Service并进行测试,比之前简便许多。在开发中这种测试方式用的比较普遍。

### 在 Gradle 中排除 Spring Boot 自带的日志系统并验证依赖配置 在 Gradle 构建工具中,Spring Boot 默认集成了一套日志系统(Logback),如果需要将其替换为其他日志实现,可以按照以下步骤操作。 #### 排除默认日志依赖 Spring Boot 使用 `spring-boot-starter-logging` 模块提供默认的日志功能。要在项目中排除该模块,可以在引入 `spring-boot-starter` 或者类似的启动器时使用 `exclude` 方法[^1]。 ```gradle dependencies { implementation('org.springframework.boot:spring-boot-starter') { exclude group: 'org.springframework.boot', module: 'spring-boot-starter-logging' } } ``` 这段代码的作用是告诉 Gradle 不要将 `spring-boot-starter-logging` 添加到项目的依赖树中。 #### 替换为其他日志实现 一旦排除了默认的日志实现,可以选择另一种日志框架来替代它。例如,切换到 Log4j2 是一种常见的做法。下面是如何添加 Log4j2 到项目的示例: ```gradle dependencies { // SLF4J 绑定到 Log4j2 的实现 implementation 'org.apache.logging.log4j:log4j-slf4j-impl:2.19.0' // Log4j2 核心库 runtimeOnly 'org.apache.logging.log4j:log4j-core:2.19.0' // 如果需要 API 定义 compileOnly 'org.slf4j:slf4j-api:1.7.36' } ``` 这些依赖项分别提供了 SLF4J 对 Log4j2 的绑定、Log4j2 的核心功能以及 SLF4J 的接口定义[^3]。 #### 验证 Dependencies 配置的正确性 为了确保上述配置生效,可以通过以下几种方式进行验证: 1. **检查生成的依赖树** 执行命令 `./gradlew dependencies --configuration runtimeClasspath` 查看最终解析后的依赖列表,确认 `spring-boot-starter-logging` 是否已被移除,并且新增的日志实现已正确加入。 2. **运行应用测试日志输出** 启动应用程序并通过打印日志消息观察实际使用的日志框架是否符合预期。例如,设置特定的日志级别或格式化样式以区分不同的日志实现。 3. **Gradle 生命周期调试** 参考之前提到的方法,在 `settings.gradle` 文件中添加任务图监听器,监控整个构建过程中涉及的任务及其执行顺序[^3]。 --- ### 示例总结 完整的 `build.gradle` 文件可能如下所示: ```gradle plugins { id 'org.springframework.boot' version '2.7.5' id 'io.spring.dependency-management' version '1.0.15.RELEASE' id 'java' } repositories { mavenCentral() } dependencies { implementation('org.springframework.boot:spring-boot-starter') { exclude group: 'org.springframework.boot', module: 'spring-boot-starter-logging' } implementation 'org.apache.logging.log4j:log4j-slf4j-impl:2.19.0' runtimeOnly 'org.apache.logging.log4j:log4j-core:2.19.0' compileOnly 'org.slf4j:slf4j-api:1.7.36' } ``` 以上配置实现了从默认日志系统的迁移过程,并确保新日志框架能够正常工作。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值