春季启动.@DataJpaTest H2嵌入式数据库创建模式

Sta*_*yuk 16 integration-testing h2 spring-test embedded-database spring-boot

我的数据层中有几个实体存储在特定模式中.例如:

@Entity
@Table(name = "FOO", schema = "DUMMY")
public class Foo {}
Run Code Online (Sandbox Code Playgroud)

我正在尝试设置H2嵌入式数据库,以便对我的数据层进行集成测试.我正在@DataJpaTest为我的测试使用注释来自动配置H2嵌入式数据库.但是,表的创建失败,因为DUMMY在初始化时不会创建模式.

有关如何在测试用例中创建表之前创建模式的任何想法?

我试过使用@Sql(statements ="CREATE SCHEMA IF NOT NOT DISMY")但没有成功.

此外,我试图spring.datasource.url = jdbc:h2:mem:test;INIT=CREATE SCHEMA IF NOT EXISTS DUMMY在我的test.properties文件中设置TestPropertySource("classpath:test.properties"),但这也不起作用.

Dav*_*nós 17

我有同样的问题,我设法通过创建schema.sql(在资源文件夹中)与内容解决

CREATE SCHEMA IF NOT EXISTS <yourschema>

文档可以在这里找到,但是由于缺乏真实的例子使得它非常复杂.警告:此脚本也在正常(非测试)环境中执行.

不是强制性的,但良好的做法是,仅在测试范围内添加h2依赖性

<dependency>
   <groupId>com.h2database</groupId>
   <artifactId>h2</artifactId>
   <scope>test</scope>
</dependency>
Run Code Online (Sandbox Code Playgroud)

  • 事实证明,您可以将`schema.sql`放在`src/test/resources`下,仅将其应用于测试 (7认同)

小智 6

我想你正在寻找这个注释:

@AutoConfigureTestDatabase(替换=替换.NONE)

例子:

@DataJpaTest
@AutoConfigureTestDatabase(replace= AutoConfigureTestDatabase.Replace.NONE)
class UserRepoTest {...}
Run Code Online (Sandbox Code Playgroud)