单元的测试方法为:
@Test
@Transactional(propagation=Propagation.REQUIRED)
@Rollback
public void test() {
userCreateService.saveUsers(2392L, "@abc.com", true, "A", new Long[]{129L, 1L, 2L, 131L, 4L}, 5);
}
设置了事务, 进入了方法里面, 调用javax.persistence.EntityManager.persist()方法都是不提交insert语句.
发个例子说明一下:
我想要插入一个user到数据库, 然后立刻把他的OPENID字段使用Oracle的sys_guid()函数来生成, 所以persist后, 调用本地查询语句来修改.
发现修改语句一直说修改了0个结果, 我查了一下Hibernate的SQL语句输出, 发现没有发出过insert语句. 这是为何呢?
请各位大神帮忙...............
黄舟2017-04-17 17:42:40
参考:
TestContext 框架解决了这个问题。默认情况下,框架将为每个测试创建并回滚一个事务。您只需编写可以假设事务存在的代码即可。如果您在测试中调用事务代理对象,它们将根据其事务语义正确运行。此外,如果测试方法在事务中运行时删除了所选表的内容,则事务将默认回滚,并且数据库将返回到执行测试之前的状态。通过测试应用程序上下文中定义的 PlatformTransactionManager bean 向您的测试类提供事务支持。
如果您想要提交事务 - 不常见,但当您想要特定测试来填充或修改数据库时偶尔有用 - 可以指示 TestContext 框架导致事务提交,而不是通过 @TransactionConfiguration 和 @Rollback 回滚注释.