SpringBoot测试jdbc时dataSource.getClass()出现空指针异常

本文介绍了在SpringBoot测试类中DataSource自动注入为空的问题,问题源于测试类缺少了@RunWith(SpringRunner.class)注解。通过添加该注解,可以确保测试类能够正确地从Spring容器中获取到bean,从而使@Autowired注解生效,避免NullPointerException的发生。修复后的代码成功从DataSource获取到了数据库连接。
摘要由CSDN通过智能技术生成
问题: DataSource自动注入为空
测试代码
package com.zkw;

import org.junit.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;

@SpringBootTest
public class Springboot06JdbcApplicationTests {
    @Autowired
    DataSource dataSource;
    @Test
    public void contextLoads() throws SQLException {

        System.err.println(dataSource.getClass());

        Connection connection = dataSource.getConnection();
        System.err.println(connection);
        connection.close();
    }
}
可能是没有读取到.yaml文件
解决方案: 在测试类上加上@RunWith注解即可

@RunWith就是一个运行器


@RunWith(SpringRunner.class)
注解的意义在于Test测试类要使用注入的bean,比如@Autowired注入的bean,
有了@RunWith(SpringRunner.class)这些bean才能实例化到spring容器中,自动注入才能生效,
不然直接一个NullPointerExecption

@RunWith(SpringRunner.class)


改变后的代码

在这里插入图片描述

结果如下

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值