意外异常是测试失败,因此您既不需要也不想捕获一个异常。
@Test
public void canConvertStringsToDecimals() {
String str = "1.234";
Assert.assertEquals(1.234, service.convert(str), 1.0e-4);
}
直到service
没有抛出一个IllegalArgumentException
因为str
其中有小数点,这将是一个简单的测试失败。
预期的异常应由 的可选expected
参数处理@Test
。
@Test(expected=NullPointerException.class)
public void cannotConvertNulls() {
service.convert(null);
}
如果程序员懒惰并 throw Exception
,或者如果他有service
return 0.0
,则测试将失败。只有一个NPE
会成功。请注意,预期异常的子类也可以工作。这对NPE
s 来说很少见,但对IOException
s 和SQLException
s 来说很常见。
在您想要测试特定异常消息的极少数情况下,您可以使用新的ExpectedException
JUnit @Rule
。
@Rule
public ExpectedException thrown= ExpectedException.none();
@Test
public void messageIncludesErrantTemperature() {
thrown.expect(IllegalArgumentException.class);
thrown.expectMessage("-400"); // Tests that the message contains -400.
temperatureGauge.setTemperature(-400);
}
现在,除非 setTemperature 抛出 anIAE
并且消息包含用户尝试设置的温度,否则测试将失败。此规则可以以更复杂的方式使用。
您的示例最好通过以下方式处理:
private void testNumber(String word, int number)
throws OutOfRangeNumberException {
assertEquals(word, service.convert(number));
}
@Test
public final void testZero()
throws OutOfRangeNumberException {
testNumber("zero", 0);
}
你可以内联testNumber
;现在,它没有多大帮助。你可以把它变成一个参数化的测试类。