【发布时间】:2011-05-09 08:26:35
【问题描述】:
为基于 Spring 的应用程序编写集成测试时遇到事务回滚问题 - 数据已插入,但事务回滚后,数据仍在数据库表中... Spring 3.0.5,JUnit 4.8.2
集成测试代码
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = { "classpath:/applicationContext.xml" })
@TransactionConfiguration(transactionManager="txManager",defaultRollback=true)
@Transactional
public class GenerateCodeStrategyTest {
@Autowired
@Qualifier(value = "generateCodeStrategy")
private Strategy generateCodeStrategy;
@Test
@Transactional
public void genCodeIntegrationTestCommunicationFailure() {
//generate some parameters
SMPPSession mockedSession = mock(SMPPSession.class);
generateCodeStrategy.setSession(mockedSession);
generateCodeStrategy.sendRequest(params);
final SubscribeInfo subscribeInfo = subscribeDao.getUserByPhone(phone);
assertNotNull(subscribeInfo);
assertEquals(phone, subscribeInfo.getPhone());
assertEquals(Status.BAD_STATUS, subscribeInfo.getStatus());
}
}
在日志中的调试模式下,我可以看到事务已启动和回滚
INFO: Began transaction (1): transaction manager [org.springframework.jdbc.datasource.DataSourceTransactionManager@1edd9b3]; rollback [true]
[main] DEBUG org.hibernate.SQL - insert into sms_subscribe (phone_cell, status, ts_subscribe, subscription_status, ts_unsubscribe, receiverIdentification, user_id) values (?, ?, ?, ?, ?, ?, ?)
INFO: Rolled back transaction after test execution for test context [[TestContext@1f18cbe testClass = GenerateCodeStrategyTest, locations = array<String>['classpath:/applicationContext.xml'], testInstance = lv.mrb.server.service.GenerateCodeStrategyTest@14f1726, testMethod = genCodeIntegrationTestCommunicationFailure@GenerateCodeStrategyTest, testException = [null]]]
也许有人知道为什么会这样?谢谢你的帮助。
更新: 该集成测试生成一些参数,然后使用 Mockito 模拟会话对象插入到策略服务中。这个模拟对象只是抛出异常,并且在这个异常中,策略服务数据通过 DAO 层保存到数据库中。然后通过 DAO 层测试向数据库发出请求并断言保存的值。
数据是通过 Hibernate 保存的,所以基本上在我的 DAO 对象中,对象是以这种方式保存的
final Session currentSession = sessionFactory.getCurrentSession();
currentSession.save(object);
sessionFactory 是 AnnotationSessionFactoryBean 其中数据源是 c3p0 ComboPooledDataSource 类
更新 2:问题出在 Mysql 引擎上,默认情况下是 MyISAM,所以我只需要将它切换到 InnoDB,现在一切正常。
【问题讨论】:
-
您能否提供测试的定义?
标签: java spring transactions integration-testing junit4