首页 文章

Spring Boot 1.4 @DataJpaTest - 创建名为'dataSource'的bean时出错

提问于
浏览
10

我已经创建了一个新的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

MyRepositoryTest

@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 回答

  • 35

    默认情况下,我们不提供嵌入式数据库 . 默认情况下, DataJpaTest 将您的 DataSource 替换为嵌入式数据库,但您没有 .

    因此,如果您想使用MySQL进行测试,请按以下步骤替换您的测试:

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

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

    testCompile('com.h2database:h2')
    

相关问题