我正在编写集成测试,在一种测试方法中,我想将一些数据写入DB然后读取它.
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath:applicationContext.xml"})
@TransactionConfiguration()
@Transactional
public class SimpleIntegrationTest {
@Resource
private DummyDAO dummyDAO;
/**
* Tries to store {@link com.example.server.entity.DummyEntity}.
*/
@Test
public void testPersistTestEntity() {
int countBefore = dummyDAO.findAll().size();
DummyEntity dummyEntity = new DummyEntity();
dummyDAO.makePersistent(dummyEntity);
//HERE SHOULD COME SESSION.FLUSH()
int countAfter = dummyDAO.findAll().size();
assertEquals(countBefore + 1,countAfter);
}
}
正如您在存储和读取数据之间看到的那样,会话应该被刷新,因为默认的FushMode是AUTO,因此数据库中实际上不能存储任何数据.
问题:我可以在会话工厂或其他地方将FlushMode设置为ALWAYS,以避免重复session.flush()调用吗?
DAO中的所有数据库调用都使用HibernateTemplate实例.
提前致谢.
最佳答案
尝试添加以下内容:
@Autowired
private SessionFactory sessionFactory;
@Before
public void myInitMethod(){
sessionFactory.getCurrentSession().setFlushMode(FlushMode.ALWAYS);
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。