- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在为我们的大型企业应用程序构建一个业务层,目前我们的单元测试不到 500 个。场景是我们有两个 public
方法,public AddT(T)
和 public UpdateT(T)
都对 private AddOrUpdateT(T)
因为很多核心逻辑在两者之间是相同的,但不是全部;他们是不同的。
因为它们是独立的公共(public) API(不考虑私有(private)实现),所以我为每个 API 编写了单元测试,即使它们是相同的。这可能看起来像
[TestMethod]
public void AddT_HasBehaviorA()
{
}
[TestMethod]
public void UpdateT_HasBehaviorA()
{
}
目前,对于这个特定的业务对象,大约有 30 个用于添加的单元测试和 40 个用于更新的单元测试,其中 30 个更新测试与添加测试相同。
这是正常的,还是我应该将常见行为抽象到一个单独进行单元测试的公共(public)帮助程序类中,并且这两个 API 只使用该帮助程序类而不是具有实现的私有(private)方法?
什么是这些情况下的最佳做法?
最佳答案
首先,了解为什么要通过单元测试覆盖这些方法很重要,因为这会影响答案。只有您和您的团队知道这一点,但如果我们假设单元测试的至少部分动机是获得可信赖的回归测试套件,那么您应该测试可观察的行为 被测系统 (SUT)。
换句话说,单元测试应该是黑盒测试。测试不应该知道 SUT 的实现细节。因此,您可以从中得出一个天真的结论是,如果您有重复的行为,那么您也应该有重复的测试代码。
但是,您的系统变得越复杂,它越依赖于常见的行为和策略,就越难实现此测试策略。这是因为您将通过系统对可能的方式进行组合爆炸。 J.B. Rainsberger explains it better than I do .
更好的替代方法通常是聆听您的测试(GOOS 推广的概念)。在这种情况下,将常见行为提取到公共(public)方法中听起来很有值(value)。然而,这本身并不能解决组合爆炸的问题。虽然您现在可以单独测试常见行为,但您还需要证明两个原始方法(Add
和Update
)使用新的公共(public)方法(而不是,例如,一些复制和粘贴的代码)。
最好的方法是使用新策略组合方法:
public class Host<T>
{
private readonly IHelper<T> helper;
public Host(IHelper<T> helper)
{
this.helper = helper;
}
public void Add(T item)
{
// Do something
this.helper.AddOrUpdate(item);
// Do something else
}
public void Update(T item)
{
// Do something
this.helper.AddOrUpdate(item);
// Do something else
}
}
(显然,您需要为类型和方法提供更好的名称。)
这使您能够使用 Behaviour Verification 证明Add
和Update
方法正确使用了AddOrUpdate
方法:
[TestMethod]
public void AddT_HasBehaviorA()
{
var mock = new Mock<IHelper<object>>();
var sut = new Host<object>(mock.Object);
var item = new object();
sut.Add(item);
mock.Verify(h => h.AddOrUpdate(item));
}
[TestMethod]
public void UpdateT_HasBehaviorA()
{
var mock = new Mock<IHelper<object>>();
var sut = new Host<object>(mock.Object);
var item = new object();
sut.Update(item);
mock.Verify(h => h.AddOrUpdate(item));
}
关于c# - 您是否应该对共享相同私有(private)实现的单独方法进行重复单元测试?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23100085/
如果需要在类外访问静态(例如单例),可以选择公共(public)静态而不是私有(private)静态,而当不需要公开函数时首选私有(private)静态(否则未命名的命名空间就可以了)——在这种情况下
在互联网上进行了一些搜索,但找不到简单的答案。我的问题集是在 Android 框架中使用 Java,但我相信这也是标准的 Java 行为。我理解 final 和 private 的定义,它们都用于变量
我有这个代码: public final class Board { private final int[][] blocks; private final int N; pr
对我来说,过去作为 Objective-C 开发人员很简单。一个类需要公开的每个字段都是一个属性,每个私有(private)字段都是一个没有 getter 或 setter 的实例变量。但我经常看到人
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我有一个在 Docker 容器中运行的应用程序。它需要来自公司私有(private) NPM 注册表(Sinopia)的一些私有(private)模块,并且访问这些需要用户身份验证。 Dockerfi
我试图理解 C# 使用 getters 和 setters 自动声明变量与 java 声明之间的区别。 在java中我通常这样做: private int test; public int getTe
我在 Azure 中创建了 VNET。我放入了一个子集 Azure Private Link,它在 VNET 之外和另一台虚拟机中调用 Azure Function。 当我尝试通过专用 IP 调用专用
我在 Azure 中创建了 VNET。我放入了一个子集 Azure Private Link,它在 VNET 之外和另一台虚拟机中调用 Azure Function。 当我尝试通过专用 IP 调用专用
我目前正在使用 Objective-C(适用于 iPhone)构建游戏。 为此,出于性能/复杂性原因,我略微打破了 MVC,并为 View (渲染器)提供了对模型的直接引用。这是因为它应该以 60fp
我已经在 ubuntu 上成功配置了 2 个虚拟主机站点(基于名称的虚拟主机)。我的 apache 版本是 2.2.22。 这两个站点都在本地主机上工作。 /etc/hosts 条目 127.0.0.
考虑下面的类 public class A { private final Map cache; public HeavyObject getThing(); } 假设不能泄漏对缓存
我有一个类,它有一个方法,我希望它只能被它的子对象访问,而不能被这个包中的其他类访问。 Modifier | Class | Package | Subclass | World ———————
本文实例讲述了JavaScript中的公有、私有、特权和静态成员用法。分享给大家供大家参考。具体分析如下: 下面的内容是在《JavaScript.DOM高级程序设计》里面摘抄出来的,比较容易理解,
我有一个用例,我已将其简化为以下程序: public class A { private int x = 100; class B { private int y = ne
问题: 类声明如下: class Select { public: template static Iterator function(Iterator , Iterator , bo
我是一名初级 PHP 程序员。我还有很多东西要学。这就是我问这个问题的原因。在一个类中,您有一个公共(public)函数,您可以从该类外部调用它。有时你有一个私有(private)函数,你可以在私有(
问题是: 何时使用私有(private)函数,何时使用嵌套函数? (我在问 F# 但也许答案可能与其他功能语言相关) 一个小例子 namespace SomeName module BinaryRea
我发现工作表中仍然可以使用私有(private)函数。它们是隐藏的,但如果用户输入他们的名字,他们就会被调用。为什么?它应该以这种方式工作吗?有没有办法完全阻止用户定义的函数在 VBA 项目之外使用?
所以我最近开始尝试使用 Kotlin,我偶然发现了这个: If a top-level declaration is marked private, it is private to the pack
我是一名优秀的程序员,十分优秀!