Junit 4.7 Rule:另一种断言异常的方法(ExpectedException)

在Junit 4.7之后,加入了一种更容易断言异常以及异常信息的方法。

异常处理

//验证抛出异常类,以及错误信息
public class TestException {
    @Rule
    public ExpectedException expectedEx = ExpectedException.none();

    @Test
    public void testValidationException() throws ValidationException {
        //断言会抛出的异常,这句一定要在抛出异常之前,否则当异常抛出时,就会阻断运行之后的语句。
        expectedEx.expect(ValidationException.class);
        //断言得到的错误信息内容。注意:断言的信息可以是原错误信息的字串
        expectedEx.expectMessage("is not passed");
        throw new ValidationException("Password is not passed.");
    }
}
//随意定义一个异常类
class ValidationException extends Exception{
    ValidationException(String msg){
        super(msg);
    }
}

expectMessage

expectedEx.expectMessage方法在断言多种返回信息时非常有用。例如当验证密码的时候,有时候可能会断言一下两种异常:
throw new ValidationException(“密码必须包含字母和数字”);
throw new ValidationException(“密码不能大于16位”);


注意事项

  1. @Rule 注解的 ExpectedException 变量声明,它必须为 public
  2. @Test处,不能使用其他断言方式,例如@Test(expected=ValidationException.class),否则不能测试通过,也就是
    @Test(expected=ValidationException.class) 和测试方法中的
    expectedEx.expectXxx() 方法是不能同时并存的
  3. 保证被测试的方法在expectedEx.expectXxx() 方法后面,不然也不能通过验证
  4. expectedEx.expectMessage()中的参数可以是subString或Matcher,就是说断言及可以是子字符串,也可以是正则表达式

你可能感兴趣的:(JUnit)