码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2016-05-12 22:39:03      阅读:178      评论:0      收藏:0      [点我收藏+]

标签:

在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 4.7 Rule:另一种断言异常的方法(ExpectedException)

标签:

原文地址:http://blog.csdn.net/ghostaaa/article/details/51354603

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!