我有一个期望特定异常的测试,例如:
@Test(expected=MyException.class)
public void testMyMethod(){
myMethod();
}
myMethod()
方法实际上抛出了MyException
的子类,我们称之为MySubclassException
。
无论如何使用@Test
注释来定义我的测试以接受MyException
的子类以及类本身吗?
我知道我可以通过捕获异常和设置标志来自行编写测试检查逻辑而不使用expected
,但我想知道JUnit是否已经支持匹配异常子类。
答案 0 :(得分:3)
框架
已经为您处理了这个问题我们举一个小例子(非常糟糕的代码): import static org.junit.Assert。*;
import org.junit.Test;
public class TestExpect {
@Test(expected=MyException.class)
public void test() throws MyException {
new Foo().foo();
}
}
有2个异常类,MyException和MyExtendedException继承自前一个,并且有一个简单的Foo类,如下所示:
public class Foo {
public void foo() throws MyException{
throw new MyExtendedException();
}
}
使用Eclipse运行器启动测试会打印一个绿色条,因为测试会引发一个Myexception实例(是POO中的关系)
如果您更喜欢阅读源代码,那么这是Junit源代码(ExpectException.java)的一个exxcerpt:
@Override
public void evaluate() throws Exception {
boolean complete = false;
try {
fNext.evaluate();
complete = true;
} catch (AssumptionViolatedException e) {
throw e;
} catch (Throwable e) {
if (!fExpected.isAssignableFrom(e.getClass())) {
String message= "Unexpected exception, expected<"
+ fExpected.getName() + "> but was<"
+ e.getClass().getName() + ">";
throw new Exception(message, e);
}
}
if (complete)
throw new AssertionError("Expected exception: "
+ fExpected.getName());
}
答案 1 :(得分:3)
如果MyException
引发MySubclassException
或myMethod()
,则测试将通过。我用这段代码测试了这个概念:
public class ExceptionTest {
private static class ExceptionA extends Exception {
}
private static class ExceptionB extends ExceptionA {
}
@Test(expected=ExceptionA.class)
public void test() throws Exception {
throw new ExceptionB();
}
}
答案 2 :(得分:0)
@Test
public void testMyMethod() {
when(foo).myMethod();
then(caughtException()).isInstanceOf(MyException.class);
}
com.googlecode.catch-exception:catch-exception:1.2.0