import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import org.springframework.test.context.transaction.TransactionConfiguration; import org.springframework.transaction.annotation.Transactional; @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations ={"classpath:/configuration/spring/beans.xml"}) @Transactional @TransactionConfiguration(transactionManager = "transactionManager", defaultRollback = false) public class TestModule{ @Test public void testAdd() { try { dao.save(module); }catch(Exception e) { e.printStackTrace(); } } }
这里需要对defaultRollback =
true
说明: true ? 测试数据不会污染数据库 : 会真正添加到数据库当中
当然这里不污染数据库只是在表中看不到数据, 但是如果你设置的主键是自动增长的话, 那么可以很明显得看出,虽然数据回滚了, 但是当你尝试不回滚新增数据到数据库的时候, 会发现ID不是连续的.所以并不是真正意义上的无污染
当然,这种方式也有他的好处,比单纯JUNIT要省去@before ,@after的方法.