JUnit Assertions vs assert

我们知道在写JUnit的单元测试Case时,要用assertEquals, assertTrue 等方法来判定某个方法的输出值是否和预期一致,如果不一致测试案例就失败。

在Java中还有一个关键字assert,它的用法是如下:

assert Expression;

Expression必须是一个布尔表达式,当Expression的值为false的时候,它会抛出AssertionError。

表面上看起来在单元测试里面用哪个都可以,但是毋庸置疑,在写JUnit单元测试的时候应该用JUnit提供的assert方法,要不然JUnit就不会提供这些方法了。那么它们两者有什么区别呢?

  1. Java的assert关键字是用于在生产代码中断言某些条件是不可能也不应该发生的。如果发生了,那么代码肯定是有问题的。比如,经常我们在代码里面可以看到一些注释,“如果代码能运行到这里,x的值肯定<满足某种条件>”,“代码是不会执行到这里的。”,像这样的情况就可以加上一个assert语句。
  2. JUnit的assertEquals等方法是断言在给定的输入下,代码的输出一定要满足期望的条件。Java的assert关键字是断言无论在何种输入条件下,语句“assert Expression”的Expression值一定为true。所以,Java的assert关键字是断言恒定不变的条件。参见这里了解更多可以使用assert的情况。
  3. assert语句需要在启动程序的时候加上-enableassertions 或者 -ea 参数才能生效。如果在JUnit的测试案例中用了assert但是又忘记了加上这个启动参数,那么assert是不会生效的,测试案例看起来都通过了,但是事实上某些测试案例可能是失败的。
  4. 一般来讲,Java的assert关键字是用在生产代码里面,JUnit的assert方法是用在测试代码里面。当然,如果非要混着用,语法上也是可以的。

我也是今天同事和我说起了assert关键字才仔细了解去了解了一下,如有不对,欢迎指正。

你可能感兴趣的:(java,JUnit,测试,单元测试)