【发布时间】:2021-04-07 18:10:45
【问题描述】:
您好,我正在编写一个 SpringBoot 应用程序,我正在编写单元测试和集成测试,但是我的集成测试失败了?
原因一:尝试通过两次执行schema.sql创建表,因此抛出表已存在异常,测试失败。
原因 2: 即使我输入了 create if not exists,它也会通过执行 data.sql 在插入时失败,因为它会尝试第二次执行脚本并且发生唯一性约束违规。我知道我可以在一开始就删除表或删除记录以消除错误。
但为什么它会运行两次?不是三次或一次?
第一次测试
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.NONE)
public class Atest {
}
第二次测试
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.NONE)
public class Btest {
}
第三次测试
@SpringBootTest
public class Ctest {
}
Atest 和 Btest 都 passes 并且他们尝试从测试数据中访问记录并且他们能够看到它。
但是 Ctest fails 由于异常
Caused by: org.h2.jdbc.JdbcSQLSyntaxErrorException: Table "tbl_test" already exists; SQL statement:
因为test->resourece 文件夹data.sql 和schema.sql 中有2 个文件。它尝试运行它们两次
我的问题:
- 为什么脚本会执行两次?
- 为什么不三次,每次测试一次?
- 我可以看到它们之间的唯一区别是
@SpringBootTest与@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.NONE)但它们仍然在一个执行周期或上下文中,因此不应该发生。 - 为什么当多个测试都有
@SpringBootTest时它不会失败(比如三个都有这个注释)。
【问题讨论】:
-
好吧,如果没有看到测试代码,很难看出问题是什么
-
因为上下文不同。一个在模拟环境下运行,另一个在没有 Web 环境的情况下运行。由于这种差异,它将加载一个新的应用程序上下文。
标签: java spring-boot testing spring-data-jpa spring-boot-test