Я использую встроенную базу данных Spring (DB по умолчанию - 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 элементом,Почему откат не происходит между тестами?