您的位置:首页 > 其它

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

2016-05-09 17:21 267 查看
在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位”);

注意事项

@Rule 注解的 ExpectedException 变量声明,它必须为 public

@Test处,不能使用其他断言方式,例如@Test(expected=ValidationException.class),否则不能测试通过,也就是

@Test(expected=ValidationException.class) 和测试方法中的

expectedEx.expectXxx() 方法是不能同时并存的

保证被测试的方法在expectedEx.expectXxx() 方法后面,不然也不能通过验证

expectedEx.expectMessage()中的参数可以是subString或Matcher,就是说断言及可以是子字符串,也可以是正则表达式
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: