在用任何语言进行测试时,每个人如何表达他们的断言消息?
我看到了三种明显的方式:
# assume failure
assert (4-2) == 2, "Subtracting 2 from 4 doesn't equal 2"
# describe success
assert (4-2) == 2, "Subtracting 2 from 4 should equal 2"
# be vauge with failure
assert (4-2) == 2, "Subtracting 2 from 4 is broken"
这显然是一个简单的例子,但你明白了。标准的做法是什么?你的工作是什么?为什么?
发布于 2008-12-20 08:45:24
断言的重要之处在于被测试的实际情况。在C语言中,您可以使用预处理器“字符串化”来输出被测试的实际情况。我的代码只是输出
Assert Failed: (4-2)==2 : Line 123, File foo.c
如果你幸运的话,你也可以得到一个堆叠垃圾堆.
发布于 2008-12-20 09:21:01
我不知道是否有“标准”,但在大多数情况下,我喜欢看到断言条件本身。这是自动完成的。不幸的是,在C#中,我不得不复制粘贴它。
Debug.Assert(4-2==2, "4-2==2");
在某些情况下,看到比条件提供的更多的信息是有用的。在这种情况下,我将断言消息视为错误消息,并声明错误的地方。
Debug.Assert(result != null, "No result returned for input '" + input + "'");
发布于 2008-12-20 16:21:48
我将断言消息视为注释:如果我能够避免,如果我能够从代码中澄清意图,我就尽量不使用它们。
通常,这是一个问题,当有几个属性您希望断言在某种程度上是相关的。将断言提取到一个名为“表示感兴趣的方面/关系”的方法中,可以更清楚地了解所发生的事情,而无需维护注释/消息。
https://stackoverflow.com/questions/383104
复制相似问题