对比两个不同版本的assertEquals()

2008-02-23 09:16:48来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

分别看一下JUnit和TestNG对assertEquals()的定义:

JUnit:

static void assertEquals(Java.lang.Object expected, java.lang.Object actual)
static void assertEquals(java.lang.String message, java.lang.Object expected, java.lang.Object actual)

TestNG:

static void assertEquals(java.lang.Object actual, java.lang.Object expected)
static void assertEquals(java.lang.Object actual, java.lang.Object expected, java.lang.String message)

忽略各参数的类型不予考虑,重新看 actual, expected, message 这三个参数的前后顺序:

JUnit中的顺序是:(message), expected, actual。

TestNG中的顺序是:actual, expected, (message)。

这其中的细微区别是,actual(实际值)与expected(期望值)的前后顺序,当message(信息文本)存在时它与另外两个参数的相对位置。在JUnit中,message(如果它存在的话)处于优先位置,其次是expected,再次是actual;而在TestNG中,恰恰是完全相反,actual处于优先位置,其次是expected,再次是message。

相比较而言,我认为TestNG对assertEquals()的定义更符合人的思维逻辑,也就是所谓的“用户友好性”另强一些。当然这只是个人观点,见仁见智嘛。

当初我第一次看到JUnit中assertEquals()的定义时,就在想,为什么不是actual在前而expected在后?今天第一次看到TestNG对assertEquals()的定义,忽然有种“英雄所见略同”的感觉。当然现在提这一出有些“马后炮”的味道。

就凭这一点,我为TestNG叫好!

上一篇: 用JavaScript脚本制作自己的色谱图
下一篇: [webservices]XFire Web服务的单元测试

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:在Weblogic Portal里加入Struts的应用程序主要步骤

下一篇:[webservices开发]集成Spring