spring-boot - Spring 靴。 @DataJpaTest H2嵌入式数据库创建架构

标签 spring-boot integration-testing h2 spring-test embedded-database

我在数据层中有几个实体以特定的架构存储。例如:

@Entity
@Table(name = "FOO", schema = "DUMMY")
public class Foo {}


我正在尝试设置H2嵌入式数据库以进行数据层的集成测试。
我在测试中使用@DataJpaTest批注来自动配置H2嵌入式数据库。但是,表创建失败,因为在数据库初始化时未创建架构DUMMY

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

我尝试使用@Sql(statements =“如果不存在假的话则创建模式”),但没有成功。

另外,我尝试在spring.datasource.url = jdbc:h2:mem:test;INIT=CREATE SCHEMA IF NOT EXISTS DUMMY文件中将test.properties设置为与TestPropertySource("classpath:test.properties")一起设置,但是那也不起作用。

最佳答案

我遇到了同样的问题,我设法通过使用内容创建schema.sql(在resources文件夹中)来解决

CREATE SCHEMA IF NOT EXISTS <yourschema>

可以在here中找到文档,但是恕我直言,缺少实际示例使它非常复杂。
警告:该脚本也在正常(非测试)环境中执行。

不是强制性的,而是一种很好的做法,仅在测试范围内添加h2依赖项

<dependency>
   <groupId>com.h2database</groupId>
   <artifactId>h2</artifactId>
   <scope>test</scope>
</dependency>

关于spring-boot - Spring 靴。 @DataJpaTest H2嵌入式数据库创建架构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39037855/

相关文章:

javascript - 如果功能 A 使用功能 B 并且我测试功能 A,它是集成测试吗?

java - Quarkus:每次测试后清理 H2 DB

java - Spring Boot MockMvc 无法使用 @PathVariable 进行测试

java - 如何在执行 jar 时从外部配置文件访问类路径

mysql - Hibernate,发生异常后不刷新Session问题

c++ - 如何在 Qt 中获取指向弹出对话框的指针,这会阻塞 QTest 中的 UI 线程

java - 如何用应用程序上下文配置文件替换 web.xml?

java - 如何启动内存数据库来测试 JPA 实体?

passwords - H2数据库密码恢复

spring-boot - 当通过 Dockerfile 上的 gradle 图像触发时,Jooq 无法找到数据库