这是关于 .NET 库 (DLL) 的。
测量单元测试用例涵盖的代码的选项有哪些?它真的值得付出努力(测量代码覆盖率)吗?我想知道覆盖 70% 的代码可能太容易了,而超过 90% 几乎不可能。
[编辑] 另一个有趣的问题(由“E Rolnicki”提出)是:什么被认为是合理的覆盖率?
这是关于 .NET 库 (DLL) 的。
测量单元测试用例涵盖的代码的选项有哪些?它真的值得付出努力(测量代码覆盖率)吗?我想知道覆盖 70% 的代码可能太容易了,而超过 90% 几乎不可能。
[编辑] 另一个有趣的问题(由“E Rolnicki”提出)是:什么被认为是合理的覆盖率?
NCover(商业版和开源版同名)和 Visual Studio 中的代码覆盖工具几乎是您在 MS 世界中的主要工具。
代码覆盖率是一个反向指标。它并没有真正向您展示哪些代码经过充分测试。就像尼克提到的那样,您可以测试该封面,但不要真正测试太多。相反,代码覆盖率会告诉您代码的哪些区域绝对没有测试。从那里,您可以决定为此代码编写测试是否有意义。
一般来说,我认为您应该进行代码覆盖,因为设置起来并不费力,而且它至少为您提供了比以前更多的代码信息。
我同意获取最后一部分代码可能是最困难的,并且可能有一点它的投资回报率没有意义。
NCover将帮助您显示覆盖范围。覆盖范围非常有用,不幸的是它显然可以被玩弄。如果你有糟糕的开发人员覆盖代码只是为了提高 %age,是的,它最终将毫无用处并隐藏未覆盖的区域。一旦你解雇了这些人,你就可以修复它并返回有用的信息。设定无法实现的覆盖目标是获得糟糕覆盖的可靠方法。
如果你在做测试驱动开发,你的代码应该在不尝试的情况下达到至少 70%。有些领域你不能或没有意义的测试覆盖,这就是 NCover 的 NoCoverage 属性派上用场的地方(你可以标记要被代码覆盖排除的类)。
不应严格遵守代码覆盖率,它应该只是一种有用的方式,可以提示您在测试中遗漏的区域。它应该是你的朋友,而不是纳粹分子!
在查看代码覆盖率时需要考虑两件事。
以这个片段为例:
if (a == 2)
{
do_A_Stuff();
}
if (b == 3)
{
do_B_Stuff();
}
运行 a = 2 的测试和 b = 3 的第二个测试。这是 100% 的代码覆盖率。但是当 a = 2 & b = 3 的测试时会发生什么?这些是“变量关系”,可能导致对覆盖率指标的过度自信。
我没有亲自使用它,但我的一位同事对 nCover ( http://www.ncover.com/ ) 发誓。
就覆盖率而言,至少在 Ruby 中,70% 是容易的,90% 是可行的,而 100% 几乎是不可能的。
Visual Studio Team System Developer Edition 包括代码覆盖率。这可以在运行单元测试时包括在内。
打开 .testrunconfig 并选择您想要数据的程序集。