一般使用Mock的流程

Mock框架可以非常容易的开发stub和mock。但是stub就需要程序员的进行开发了。所以,我们只讲Mock。
mock:使用easymock等包,在程序代码中向被测试代码注入“依赖部分”,通过代码可编程的方式模拟出函数调用返回的结果。
stub:自己写代码代替“依赖部分”。它本身就是“依赖部分”的一个简化实现。
stub之所以在现代仍然存在,是因为部分老代码不支持注入。所以只能给出一个依赖部分进行简化实现。
Mock框架需要和JUnit,TestNG这种测试框架并行使用。
<dependency>
<groupId>org.mockito</groupId>
<artifactId>mockito-all</artifactId>
<version>1.9.5</version>
<scope>test</scope>
</dependency>
一个典型的测试如下
@Test
public void when_thenReturn(){
//mock一个Iterator类
Iterator iterator = mock(Iterator.class);
//预设当iterator调用next()时第一次返回hello,第n次都返回world
when(iterator.next()).thenReturn("hello").thenReturn("world");
//使用mock的对象
String result = iterator.next() + " " + iterator.next() + " " + iterator.next();
//验证结果
assertEquals("hello world world",result);
}
最长使用的就是上面那句,Mockito.when(…).thenReturn(…)。
Mockito中的Mock和Spy都可用于拦截那些尚未实现或不期望被真实调用的对象和方法,并为其设置自定义行为。二者的区别在于
- Mock声明的对象,对函数的调用均执行mock(即虚假函数),不执行真正部分。
使用@Mock生成的类,所有方法都不是真实的方法,而且返回值都是NULL。 - Spy声明的对象,对函数的调用均执行真正部分。
使用@Spy生成的类,所有方法都是真实方法,返回值都是和真实方法一样的。
4152

被折叠的 条评论
为什么被折叠?



