Załóżmy fragment kodu testowego:Czy istnieje sposób na coś takiego, jak argument JUnit Assert w metodzie weryfikacji Mockito?
Observable model = Class.forName(fullyQualifiedMethodName).newInstance();
Observer view = Mockito.mock(Observer.class);
model.addObserver(view);
for (Method method : Class.forName(fullyQualifiedMethodName).getDeclaredMethods())
{
method.invoke(model, composeParams(method));
model.notifyObservers();
Mockito.verify(
view, Mockito.atLeastOnce()
).update(Mockito.<Observable>any(), Mockito.<Object>any());
}
Mockito.verify
metoda zgłasza wyjątek, jeśli metoda w modelu nie został wywołany Observable.setChanged()
metody.
Problem: bez dodawania loggers/System.print.out
Nie mogę stwierdzić, jaka jest aktualna metoda, która nie powiodła się. Czy istnieje sposób, że coś podobnego do jUnit Assert
metod:
Assert.assertEquals(
String.format("instances %s, %s should be equal", inst1, inst2),
inst1.getParam(),
inst2.getParam()
);
ROZWIĄZANIE:
verify(observer, new VerificationMode()
{
@Override
public void verify(VerificationData data)
{
assertTrue(
format(
"method %s doesn't call Observable#setChanged() after changing the state of the model",
method.toString()
),
data.getAllInvocations().size() > 0);
}
}).update(Mockito.<Observable>any(), Mockito.<Object>any());
Przekazywanie przyczyny jako drugiego argumentu jest zwykle lepsze niż łączenie wiadomości. 'throw new MockitoAssertionError (" message ", e)' – Kapep
MockitoAssertionError nie ma konstruktora z parametrami MockitoAssertionError (String, Exception) Używam 'new AssertionError (" message ", exception)', ponieważ jest to typ wyjątku jest wyrzucane przez JUnit dla stwierdzeń. –