我的 Spring-Boot-Mvc-Web 应用程序在 application.properties
文件中有以下数据库配置:
spring.datasource.url=jdbc:h2:tcp://localhost/~/pdk
spring.datasource.username=sa
spring.datasource.password=
spring.datasource.driver-class-name=org.h2.Driver
这是我做的唯一配置。我在任何地方都没有任何其他配置。尽管如此,Spring 和子系统会在每个 Web 应用程序运行时自动重新创建数据库。数据库在系统运行时重新创建,而它在应用程序结束后包含数据。
我不理解这个默认值,并期望这适合测试。
但是当我开始运行测试时,我发现数据库只重新创建一次。由于测试没有按预定义的顺序执行,这完全没有意义。
所以,问题是:如何有意义?即如何在每次测试之前重新创建数据库,因为它在应用程序首次启动时发生?
我的测试类标题如下:
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = myapp.class)
//@WebAppConfiguration
@WebIntegrationTest
@DirtiesContext
public class WebControllersTest {
如您所见,我在课堂上尝试了 @DirtiesContext
并没有帮助。
更新
我有一颗豆子
@Service
public class DatabaseService implements InitializingBean {
有一个方法
@Override
@Transactional()
public void afterPropertiesSet() throws Exception {
log.info("Bootstrapping data...");
User user = createRootUser();
if(populateDemo) {
populateDemos();
}
log.info("...Bootstrapping completed");
}
现在我用 populateDemos()
方法来清除数据库中的所有数据。不幸的是,尽管 @DirtiesContext
,它并没有在每次测试之前调用。为什么?
原文由 Dims 发布,翻译遵循 CC BY-SA 4.0 许可协议
实际上,我认为你想要这个:
http://docs.spring.io/autorepo/docs/spring-framework/4.2.6.RELEASE/javadoc-api/org/springframework/test/annotation/DirtiesContext.html
你把它放在你的测试课上。