使用 spy() 監(jiān)視真實(shí)的對(duì)象
在使用 when(foo.call()).thenReturn("foo"); 的時(shí)候,事實(shí)上并沒(méi)有真的調(diào)用 foo.Call(),而是在運(yùn)行測(cè)試的時(shí)候,在調(diào)用 foo.call() 的時(shí)候都給你返回 foo 這個(gè)返回值:當(dāng)然這個(gè)前提是 foo 是一個(gè) Mock 對(duì)象(意味著加了 @Mock 注解)。
如果要調(diào)用一個(gè)真實(shí)的對(duì)象的方法,同時(shí)又要控制它的返回值,那么可以這樣做:
doReturn("foo").when(foo).call();
當(dāng)然,這個(gè) foo 需要是一個(gè) spy 對(duì)象:
foo=spy(fooBase);
拿官方的例子做栗子:
List list = new LinkedList();
List spy = spy(list);
// Right
doReturn("foo").when(spy).get(0); 【0】
// Wrong
when(spy.get(0)).thenReturn("foo"); 【1】
此處,spy 是一個(gè)監(jiān)視 list 的對(duì)象。
【0】當(dāng)調(diào)用 spy.get(0) 的時(shí)候,并不是真的去調(diào)用這個(gè)方法,而是直接返回 foo。 【1】當(dāng)調(diào)用 spy.get(0) 的時(shí)候,會(huì)直接調(diào)用 list.get(0),因?yàn)樗且粋(gè)真實(shí)的對(duì)象,然后因?yàn)檫@個(gè) list 的 size()==0 因此會(huì)拋出一個(gè)數(shù)組越界的異常。