【发布时间】:2014-08-11 17:09:21
【问题描述】:
我有一个 Spring-JUnit 测试,其设置方法使用 JPA 实体来设置测试数据。在测试本身中,遗留代码使用 JDBC 模板来查询插入的测试数据。当遗留代码发出查询时,对 jdbcTemplate.query(...) 的调用会挂起。
我的单元测试如下所示:
@TransactionConfiguration(defaultRollback = false)
@ContextConfiguration(locations = { "/testContext.xml" })
@Transactional
public class MyTest {
@PersistenceContext(unitName = "someUnit")
private EntityManager entityManager;
@Test
public void test() {
// here some legacy Code is called that uses JDBC Templates to query
// the inserted test data. The legacy code hangs upon jdbcTemplate.query(...)
}
@Before
public void before() {
this.entityManager.persist(new Entity1(...));
this.entityManager.persist(new Entity2(...));
}
}
我的问题是:为什么 enitymanager 在退出 before() 方法时不提交?或者它是否提交并立即启动一个仍然引用存储实体的新事务?我还尝试不使用 junit 注释 @Before 注释并手动调用 before() 方法。但这给出了相同的结果。
非常感谢任何建议。
【问题讨论】:
标签: java spring jpa junit transactions