【SpringBoot】Junit单元测试遇到的一些问题

本文总结了SpringBoot Junit单元测试中遇到的四个问题及其解决方法:1.测试方法不能有返回值;2.NullPointerException,需添加@RunWith(SpringRunner.class);3.注入失败,需使用@SpringBootTest指定启动类;4.多环境配置导致的问题,通过@ActiveProfiles选择环境。此外,还介绍了如何通过基类优化测试类的注解使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

情况 ①:不能有返回值

@Controller
public class FileControllerTest{

    @Autowired
    private FileController fileController;

    @Test
    public String testDownload(){
        fileController.download("2dd4209286df4f14b703890ccdc3d2ff");
        return "";
    }
}

报错:

java.lang.Exception: Method testDownload() should be void

	at org.junit.runners.model.FrameworkMethod.validatePublicVoid(FrameworkMethod.java:99)
	at org.junit.runners.model.FrameworkMethod.validatePublicVoidNoArg(FrameworkMethod.java:74)
	at org.junit.runners.ParentRunner.validatePublicVoidNoArgMethods(ParentRunner.java:155)
	...

解决办法:测试用例方法是不能有返回值的,必须是public void的

情况 ②:NullPointerException

@Controller
public class FileControllerTest{

    @Autowired
    private FileController fileController;

    @Test
    public void testDownload(){
        fileController.download("2dd4209286df4f14b703890ccdc3d2ff");
    }
}

报错:

java.lang.NullPointerException 
	at com.yealink.version.controller.FileControllerTest.testDownload(FileControllerTest.java:20)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	...

解决办法:意味着要在测试类顶部加上注解@RunWith(SpringRunner.class)

情况 ③: Bean注入失败

                
### 解决Spring Boot项目中使用JUnit4进行单元测试时遇到的包找不到类的问题 当在Spring Boot项目中使用JUnit4执行单元测试时,如果遇到`package does not contain class`错误,通常是因为以下几个原因: #### 1. 测试类路径配置不正确 确保测试类位于正确的目录结构下。按照Maven或Gradle的标准约定,源码应放在`src/main/java`,而测试代码则应该放置于`src/test/java`。 对于Spring Boot应用程序而言,推荐的做法是在项目的根目录创建一个名为`test`的新文件夹,并在此基础上构建相应的包层次结构[^1]。 ```java // Example of correct placement for a test class under src/test/java/com/example/demo/ package com.example.demo; import org.junit.Test; import static org.junit.Assert.*; public class DemoApplicationTests { @Test public void contextLoads() { assertTrue(true); } } ``` #### 2. 缺少必要的依赖项 确认已将JUnit4及相关支持库添加到项目的构建工具配置文件(如pom.xml)中。缺少这些依赖可能导致编译器无法识别测试框架中的注解和方法。 ```xml <!-- Add JUnit dependency --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.13.2</version> <scope>test</scope> </dependency> <!-- Ensure spring-boot-starter-test is included which includes JUnit support --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> ``` #### 3. 注解扫描范围设置不当 有时即使测试类存在于预期位置,仍然会因为组件扫描机制未能覆盖该区域而导致问题发生。此时可以尝试通过显式指定要扫描的基础包来解决问题。 ```java @RunWith(SpringRunner.class) @SpringBootTest(classes = {DemoApplication.class}, webEnvironment = WebEnvironment.RANDOM_PORT) @ContextConfiguration(initializers = ConfigFileApplicationContextInitializer.class) @ComponentScan(basePackages = "com.example") // Specify base packages explicitly here. public class DemoApplicationTests {} ``` 以上措施有助于排查并修复由于包定义不清所引起的“找不到类”的异常情况。值得注意的是,在现代版本的Spring Framework中已经不再建议使用`ref local`属性,而是采用更通用的方式来进行bean引用[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值