当前位置:  开发笔记 > 编程语言 > 正文

使代码内部但可用于其他项目的单元测试

如何解决《使代码内部但可用于其他项目的单元测试》经验,为你挑选了2个好方法。

我们将所有单元测试都放在他们自己的项目中.我们发现我们必须将某些类公开而不是内部仅用于单元测试.无论如何都要避免这样做.通过将类公开而不是密封来实现内存含义是什么?



1> Ash..:

如果您使用的是.NET,则InternalsVisibleTo程序集属性允许您创建"朋友"程序集.这些是特定的强名称程序集,允许访问内部类和其他程序集的成员.

请注意,这应该谨慎使用,因为它紧密耦合相关的组件.InternalsVisibleTo的常见用途是用于单元测试项目.由于上述原因,它可能不适合在您的实际应用程序集中使用.

例:

[assembly: InternalsVisibleTo("NameAssemblyYouWantToPermitAccess")]
namespace NameOfYourNameSpace
{


我建议在属性周围加一个#if DEBUG,然后在debug中进行单元测试.这样你就可以确保该属性不是在发布代码上设置的.
不同意.如果我使用非常薄的公共API构建复杂组件,那么仅通过公共API进行测试是不切实际且不切实际的.你最终会得到一个无法维持的泥球.相反,我会仔细定义内部单元并单独测试它们.正如杰里米·D·米勒(Jeremy D. Miller)经常说的那样:"在你考试之前测试一下".
那么,为什么限制测试来调试构建呢?
此外,只是一个挑剔,没有必要强烈命名"朋友"集会(可能是一个很好的做法 - 即使我个人的口味否则,但不是强制性的).

2> Josh..:

如果它是一个内部类,那么它不能被孤立地使用.因此,除了测试在内部使用该对象的其他类之外,您不应该真正测试它.

正如您不应该测试类的私有成员一样,您不应该测试DLL的内部类.这些类是一些可公开访问的类的实现细节,因此应该通过其他单元测试来很好地执行.

这个想法是你只想测试一个类的行为,因为如果你测试内部实现细节,那么你的测试将是脆弱的.您应该能够在不破坏所有测试的情况下更改任何类的实现细节.

如果您发现确实需要测试该类,那么您可能想要首先重新检查该类为什么是内部的.


我不一定同意这一点,因为这些类对DLL内的其他类是"公开的",并且该类的功能应该是独立测试的
我也不同意.单位是单位,必须单独测试.
伟大的一般准则,但让我们不要教条.测试有两个主要目的:1)回归 - 确保你没有破坏某些东西,2)提高开发速度.如果每次我想编写一行代码时我都必须提供大量服务,那么我将阻碍开发.如果我有一个复杂的内部部分,我希望能够孤立地开发和测试.相反,我不希望所有测试都被隔离(因此降低了回归测试值,或重复测试代码),但有些代码证明了隔离.也许关键是要使它成为一个单独的组件.
OP在这里是正确的。您正在将测试耦合到内部实现。因此,您的团队永远是修补测试和可怕的模拟代码的奴隶。仅测试公共API,无论是打包的lib API还是网络公开的API。所有代码应可通过前门执行。测试实现是TDD在很大程度上消失的原因,它实际上是测试整个应用程序的每个类的巨大PITA,而不是专注于确保系统行为。我认为几乎每个人,包括“权威”书籍,都犯了这个错误或没有弄清楚。
推荐阅读
周扒pi
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有