加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

HSQLDB / Spring单元测试不会回滚

发布时间:2020-12-15 01:20:50 所属栏目:大数据 来源:网络整理
导读:我正在使用Spring的嵌入式数据库(默认数据库为HSQLDB)来运行一些单元测试.我的背景如下: bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManger" property name="dataSource" ref="dataSource"//beanjdbc:

我正在使用Spring的嵌入式数据库(默认数据库为HSQLDB)来运行一些单元测试.我的背景如下:

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManger">
    <property name="dataSource" ref="dataSource"/>
</bean>

<jdbc:embedded-database id="dataSource">
   <jdbc:script location="blah"/>
</jdbc:embedded-database>

单元测试是这样的:

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
@TransactionConfiguration(transactionManager="transactionManager",defaultRollback=true)
@Transactional
public class DAOTest(){

   @Autowired
   public MyDAO myDAO;


   @Test
   public void test1(){
      List list = myDAO.getHibernateTemplate.loadAll(Hit.class);
      assertThat(list.size(),equalTo(0));

      Hit hit = new Hit();
      myDAO.saveHit(hit);

      list = myDAO.getHibernateTemplate.loadAll(Hit.class);
      assertThat(list.size(),equalTo(1));
   }

   @Test
   public void test2(){

      List list = myDAO.getHibernateTemplate.loadAll(Hit.class);
      assertThat(list.size(),equalTo(0));
   }

}

当我运行上述命令时,测试2失败,因为返回了包含1个元素的列表.为什么两次测试之间没有发生回滚?

最佳答案
所以想通了.问题是我正在使用DataSourceTransactionManager,但是在代码中使用了Hibernate,因此需要使用HibernateTransactionManager.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读