分别看一下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叫好!
以上就是对比两个不同版本的assertequals()的内容。
