什么是Spring TestContext?
Spring TestContext是Spring提供的一套基于注解的Test框架,Spring TestContext有非常好的兼容性,可以无缝兼容JUnit,TestNG等单元测试框架,而且在其基础上增加更多的功能
Spring TestContext为我们带来什么?
在Spring应用大行其道的今天,使用Spring来构建应用已经是再普通不过的事情,但当使用JUnit,TestNG等传统的单元测试技术和Spring进行结合的时候,就会出现很多并不如意的事情
1.Spring容器初始化问题:此问题已于JUnit4中被解决,通过使用@BeforeClass
可以有效防止Spring容器被多次初始化的问题
2.硬编码获取Bean:此问题是由于JUnit并不兼容Spring,所以当单元测试运行
的时候,无法解释Spring独有的注解,从而需要使用硬编码来获取Bean
3.数据现场破坏:JUnit当中可以使用DBUnit来进行数据现场维护的解决方案,
详情可以通过笔者的DBUnit使用了解DBUnit,Spring TestContext通过AOP
声明式事务来对单元测试进行回滚,有效的解决了数据现场的问题
4.事务:通常我们的单元测试都需要和数据库进行交互,但传统的JUnit的
组成单元为TestCase,并不存在事务的概念,而我们大多数情况下都需要
观察事务的执行过程或总体的性能,特别是对长事务模块的测试,
Spring TestContext允许单元测试支持事务的控制
Spring TestContext使用:
首先为Maven增加Spring的依赖,由于Spring有众多依赖,这里就不给出代码了
以下为Spring TestContext的代码
请留意上面代码中testMain上的4个注解
@ExpectedException:此形式和@Test(expected=RuntimeException.class)一样,表示该单元测试应该抛出RuntimeException的错误,否者测试不通过,但建议使用JUnit提供的
@Timed:Timed和@Test(timeout=1000)有所不同的,@Test(timeout=1000)代表被注解的方法单体执行超过1秒就会测试失败,但@Timed()为测试整个事务从开始到执行testMain再结束的总耗时,而且会把@Repeat的重复也计算在总耗时内
@Repeat:Repeat代表此方法将会重复执行100次,注意,会重复执行@Before和@After方法
@Rollback:这里是Spring TestContext我认为最大的魅力所在,只需一行简单的注解就可以实现控制回滚操作,此时可以覆盖基类中回滚默认为true的限制,可以控制是否回滚事务, true为回滚,false为不回滚
@NotTransaction:请注意这个注解,在2.5版本此注解为声明该单元测试不需要事务支持,但在3.0版本后认为单元测试当中应该都要有事务控制,所以此注解已被Deprecated(不建议再使用)
除此以外Spring TestContext还提供了很多方便的操作让我们使用
总结:
Spring TestContext使用极其简单,通过简单的注解就能扩展JUnit单元测试,弥补了JUnit在测试Spring应用时的不足和空白,还可以使用Spring自身的注解对依赖进行注入,简化了此前每次获取Bean的烦恼,在Spring应用中请毫不犹疑的使用Spring Test,在Spring TestContext当中除了支持JUnit4以外,还支持JUnit3.8,TestNG等,只需将单元测试类分别继承AbstractTransactionalJUnit38SpringContextTests和AbstractTransactionalTestNGSpringContextTests即可,