10

我有在内存数据库上执行的集成测试。每个测试的签名或多或少看起来像这样:

@RunWith(SpringRunner.class)
@SpringBootTest
@Sql("/clean-data-in-all-tables.sql")
public class SomeTest { 
    @Test
    public void shouldDoSomehting() {}
}

在测试上下文初始化期间,数据库模式由 Hibernate 重新创建:

spring:
  jpa:
    hibernate:
      ddl-auto: create-drop

我希望在上下文初始化和数据库模式生成之后执行 sql 脚本。然而,在某些情况下clean-data-in-all-tables.sql,在模式生成之前执行它会失败,因为它需要尚未创建的表。

我按照我解释的方式编写了 500 多个测试,它们都运行良好,直到我添加了一些类似的测试。

当我通过 Gradle 或 IntelliJ 一起执行测试时,测试失败。请注意,失败的测试不是最近添加的测试。这是与我添加的完全无关的旧测试。同样奇怪的是,如果我通过 IntelliJ 一个一个地运行失败的测试,它们运行良好。

它看起来像 spring-boot 的错误,但我仍然试图找到一种解决方法。与此同时,我尝试了很多方法来解决这个问题,但没有一个是有帮助的。

请分享您对我的代码有什么帮助以及我的代码有什么问题的想法。

更新: 找到解决方法:将spring.jpa.hibernate.ddl-autofrom更改create-dropcreate解决问题。

但问题仍然悬而未决,这种奇怪行为的原因是什么?

4

1 回答 1

2

一种可能的解决方案(我不确定您是否愿意使用 DBUnit)可以是:

1)创建抽象存储库集成测试:

@TestExecutionListeners({DbUnitTestExecutionListener.class})
@SpringApplicationConfiguration(classes = Application.class)
@DirtiesContext
public abstract class AbstractRepositoryIT extends AbstractTransactionalJUnit4SpringContextTests {
}

2)创建“真正的”集成测试:

@DatabaseSetup(SomeEntityRepositoryIT.DATASET)
@DatabaseTearDown(type = DatabaseOperation.DELETE_ALL, value = {"dataset.xml})
public class SomeEntityRepositoryIT extends AbstractRepositoryIT {
...
}

在文件 dataset.xml 中,您可以为测试等设置初始状态... 更多信息可以在这里找到

于 2017-05-11T12:24:14.320 回答