以下のコードを見ると、呼び出しが 1 回だけ発生すると予想されますgetSand()
が、テストは 4 回の呼び出しで失敗しています。これらの通話はどこで行われていますか? への呼び出しが 1 回だけであることを保証するテストを作成したいと考えていgetSand()
ます。
ソース
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Answers;
import org.mockito.Mock;
import org.mockito.runners.MockitoJUnitRunner;
import static org.mockito.Mockito.times;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
@RunWith(MockitoJUnitRunner.class)
public class DeepSandTest {
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
SandBox mockSandBox;
@Test
public void should(){
when(mockSandBox.getSand().doA()).thenReturn(1);
when(mockSandBox.getSand().doB()).thenReturn(1);
when(mockSandBox.getSand().doC()).thenReturn(1);
DeepSand deepSand = new DeepSand(mockSandBox);
deepSand.getTipple();
verify(mockSandBox, times(1)).getSand();
}
public class DeepSand{
private SandBox sandBox;
public DeepSand(SandBox sandBox) {
this.sandBox = sandBox;
}
public void getTipple(){
Sand sand = sandBox.getSand();
sand.doA();
sand.doB();
sand.doC();
}
}
public interface SandBox{
public Sand getSand();
}
public interface Sand{
public Integer doA();
public Integer doB();
public Integer doC();
}
}
出力
org.mockito.exceptions.verification.TooManyActualInvocations:
mockSandBox.getSand();
Wanted 1 time:
-> at DeepSandTest.should(DeepSandTest.java:26)
But was 4 times. Undesired invocation:
-> at DeepSandTest.should(DeepSandTest.java:20)
詳細Java 1.6、JUnit 4.11、Mockito 1.9.5
学んだ教訓
ディープ スタブをモック オブジェクトのツリーと考える場合は、リーフの動作をセットアップするために必要な呼び出しチェーンにノードが含まれているため、リーフ (「チェーンの最後のモック」) のみを検証する必要があります。別の言い方をすれば、リーフのセットアップ中にノードが呼び出されます。