Oft genügt es, Objekte zu erstellen, die zu den erwarteten Parameterwerten gleich sind:
context.checking(new Expectations() {{
allowing(calculator).add(1, 2);
will(returnValue(3));
DateTime loadTime = new DateTime(12);
DateTime fetchTime = new DateTime(14);
allowing(reloadPolicy).shouldReload(loadTime, fetchTime);
will(returnValue(false));
}});
JMock auch einige vordefinierte Einschränkungen bietet:
context.checking(new Expectations() {{
allowing(calculator).sqrt(with(lessThan(0));
will(throwException(new IllegalArgumentException());
}});
Sie können auch einen benutzerdefinierten Matcher verwenden with
mit :
context.checking(new Expectations() {{
DateTime loadTime = new DateTime(12);
allowing(reloadPolicy).shouldReload(with(equal(loadTime)), with(timeGreaterThan(loadTime));
will(returnValue(false));
}});
Hier timeGreaterThan
werden könnte wie folgt definiert:
public class TimeGreaterThanMatcher extends TypeSafeMatcher<DateTime> {
private DateTime minTime;
public TimeGreaterThanMatcher(DateTime minTime) {
this.minTime = minTime;
}
public boolean matchesSafely(DateTime d) {
return d != null && minTime.isBefore(d);
}
public StringBuffer describeTo(Description description) {
return description.appendText("a DateTime greater than ").appendValue(minTime);
}
public static Matcher<DateTime> timeGreaterThan(DateTime minTime) {
return new TimeGreaterThanMatcher(minTime);
}
}
die JMock Cookbook Für weitere Informationen siehe