有一个带有 h2 数据库的 Spring Boot 应用程序,用作主数据库。还有一个resource/schema.sql
由 Spring Boot 在启动时加载。
但在集成测试期间@SpringBootTest
Spring Boot 确实not加载这个schema.sql
。相反,它需要在存在时设置嵌入式数据库h2
数据库已经。
有没有办法执行schema.sql
没有嵌入数据源配置?并且对所有测试只执行一次(例如使用@Sql
为所有测试创建模式不是一个解决方案)?
用注释你的类或方法@Sql(scripts = "classpath:schema.sql", executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD)
schema.sql 位于资源文件夹中。
如果您的测试被标记为集成测试,则需要此选项。如果您正在运行单元测试或只是在启用单元测试的情况下进行编译(默认情况下),Spring Boot 将为您执行此操作。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)