一、问题:如何将mock的类自动注入到待测类,特别是在没有setter方法的情况下。
  解答:
  前提:待测的service类及其依赖的其他类都是处在被spring管理中的。
  做法:在测试类中,只要将待测的类标注为@InjectMocks,将其依赖的其他类标注为 @Mock,
  可以使用MockitoAnnotations.initMocks(this);这句话自动将依赖的类注入待测类,如果依赖类在spring的管理下有自己的name,那么甚至在待测类中都不需要写setter方法。
  例:
  1、待测类
@Component("abcService")
public class AbcService {
@Resource(name="aaaDao")
private AaaDao aaaDao;
@Resource(name="bbbDao")
private BbbDao bbbDao;
......//注:此处省略的代码中并不包含aaaDao和bbbDao的setter方法。
}
  2、测试类
public class AbcServiceTest{
@InjectMocks
AbcService abcService;
@Mock
AaaDao aaaDao;
@Mock
BbbDao bbbDao;
@Before
public void setup(){
MockitoAnnotations.initMocks(this);//这句话执行以后,aaaDao和bbbDao自动注入到abcService中。
//在这之后,你可以放心大胆地使用when().then()等进行更详细的设置。
}
}
  二、问题:如何对连续的调用进行不同的返回
  对连续的调用进行不同的返回 (iterator-style stubbing)
  还记得在实例2中说道当我们连续两次为同一个方法使用stub的时候,他只会使用新的一次。但是在某一个方法中我们确实有很多的调用怎么办呢?mockito当然想到这一点了:
when(mock.someMethod("some arg"))
.thenThrow(new RuntimeException())
.thenReturn("foo");
//First call: throws runtime exception:
mock.someMethod("some arg");
//Second call: prints "foo"
System.out.println(mock.someMethod("some arg"));
//Any consecutive call: prints "foo" as well (last stubbing wins).
System.out.println(mock.someMethod("some arg"));
  当然我们也可以将第一句写的更简单一些:
  when(mock.someMethod("some arg"))
  .thenReturn("one", "two", "three");