我正在使用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.