3

我有一个用例,我试图确保在我的类中调用特定方法时引发抽象异常。

我正在使用 Mockito 来执行此操作,但注意到 Mockito 在调用该方法时根本不会抛出异常。

要测试的类:

public void doSomething() throws CustomException {
  try {
    Collection<T> results = dao.getDatabaseResults();
      } catch (ProblemException e) {
          throw new CustomException("There was an exception", e);
  }
}

问题异常类:

public abstract class ProblemException extends RuntimeException {

  public ProblemException(String message) {
      super(message);
  }

  public ProblemException(String message, Throwable e) {
      super(message, e);
  }

测试类:

public testDoSomething() throws Exception {
   CustomDAO mockDAO = Mockito.mock(CustomDAO.class);

   Mockito.when(mockDAO.getDatabaseResults()).thenThrow(new ProblemException);

   try {
       foo.doSomething();
       Assert.fail();
   } catch (CustomException e) {
      //Some more asserts
   }

目前,上述测试类无法编译,因为您无法创建抽象类的新实例。

我无权更改 AbstractException 类,也无法更改 DAO 类上的 getDatabaseResults() 方法引发的异常类型。

你对这个问题的最干净的解决方案有什么建议吗?

我能想到的一件事是在我的 doSomething() 方法中捕获 RuntimeException(因为 ProblemException 扩展了此类)。我只是好奇是否有更好的方法?

谢谢

4

1 回答 1

17

你不能直接实例化一个抽象类,但你可以很容易地实例化一个匿名子类,在这种情况下这很简单,因为你不需要定义任何方法:

Mockito.when(mockDAO.getDatabaseResults()).thenThrow(new ProblemException(){});

或者,您可以只使用另一个模拟:

Mockito.when(mockDAO.getDatabaseResults()).thenThrow(Mockito.mock(ProblemException.class));

如果抽象类强制定义您在测试中不关心的其他方法,这将是有意义的。

于 2013-04-27T12:44:23.763 回答