Spring Boot 1.4 @DataJpaTest - 创建名为“dataSource”的Bean时出错

2022-09-01 07:59:15

我已经创建了一个新的spring boot 1.4应用程序,想尝试使用@DataJpaTest进行一些测试,但不断收到以下错误消息

由以下原因引起:org.springframework.beans.factory.BeanCreationException:创建名为“dataSource”的bean时出错:init方法的调用失败;嵌套异常是 java.lang.IllegalStateException:无法确定用于测试的嵌入式数据库。如果你想要一个嵌入式数据库,请在类路径上放一个受支持的数据库。

src/main/resources/application.properties

spring.datasource.url=jdbc:mysql://localhost/my_db
spring.datasource.username=user
spring.datasource.password=password
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

我的存储库测试

@RunWith(SpringRunner.class)
@DataJpaTest
final public class MyRepositoryTest {
}

build.gradle

dependencies {
    compile 'org.springframework.boot:spring-boot-starter-web',
            'org.springframework.boot:spring-boot-starter-data-jpa',
            'mysql:mysql-connector-java',
            'org.projectlombok:lombok:1.16.10'

    testCompile('org.springframework.boot:spring-boot-starter-test')
}

任何想法我做错了什么?


答案 1

默认情况下,我们不提供嵌入式数据库。默认情况下,将 用嵌入式数据库替换您的数据库,但您没有一个。DataJpaTestDataSource

因此,如果您想使用MySQL进行测试,请按如下方式替换测试:

@RunWith(SpringRunner.class)
@DataJpaTest
@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)
final public class MyRepositoryTest {
}

如果要将这些测试使用内存中数据库,则需要向测试类路径添加一个数据库。将其添加到您的 gradle 文件中

testCompile('com.h2database:h2')

答案 2

请在您的课程之前添加此内容。

@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)

它肯定会运行。


推荐