- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
目前我正在编写一个测试驱动的项目,我坚持测试以下行为。
我有一个名为 Menu
的界面,可以通过 addEntry
方法向其中动态添加条目。还有另一个包含 Menu
对象的类。我们称它为 MenuPresenter
。当调用特定方法(例如 someAction(string title)
)时,MenuPresenter
应该实例化一个带有接收到的标题的 Entry
对象并将其添加到Menu
对象。 Entry
对象的实例化发生在 MenuPresenter
内的工厂方法中。
测试的行为应该是WhenSomeActionIsCalledShouldAddAnEntryContainingTitleToMenu
但是我没有找到编写测试的正确方法。我想出了两种主要的可能性来测试它,但实际上我不喜欢这两种可能性,因为(稍后)提到的缺点。
Menu
的 MenuSpy
,它有一个 getAddedEntry
方法。像这样,您可以提取添加的 Entry
并检查对象的状态EXPECT_TRUE(entry->getTitle() == title);
缺点:要检查 Entry
对象的状态,我必须使用仅用于测试原因的 getter 方法扩展接口(interface)的 API,或者使用公共(public)成员变量。这允许每个客户端访问每个Entry
实现的内部结构。因此,客户端与内部结构耦合。
EntryFactory
接口(interface)扩展系统,该接口(interface)有一个makeEntry(std::string title)
-方法。像这样可以实现 EntryFactorySpy
并可以检查是否使用正确的参数(标题)调用了 makeEntry
方法。在另一个测试中,我们可以实现一个 EntryFactoryStub
,它返回一个特定的 Entry
对象。然后我们可以检查(通过 MenuSpy
)MenuPresenter
是否已将从工厂接收到的条目添加到菜单中。然后在工厂的单元测试中测试 Entry
对象的实例化。缺点:因为我测试了工厂的makeEntry
方法的调用,使用工厂创建条目的算法是固定的。该测试与 MenuPresenter
的内部结构紧密耦合。更改算法(例如,现在使用工厂方法会破坏测试,否则应用程序的预期行为会中断。
对于应用程序的行为而言,MenuPresenter
是否使用 EntryFactory
创建 Entry
本身应该不重要。这就是为什么我更喜欢第一种方式。但我不希望客户端的 Entry
仅仅因为测试原因而耦合到 Entry
的内部结构。
这只是我的问题的一个例子。实际上,条目不仅是用字符串创建的。它获取其他复杂对象作为 shared_ptr。这是我不想使用公共(public) getter 方法的另一个原因。像这样可以从 Entry
中提取复杂对象并更改它(是的,我可以给出一个 const shared_ptr,但这对我来说似乎不是一个好习惯。)
问题是,有人知道解决我的问题的测试模式或解决方案吗?意思是测试是否将正确的 Entry
对象添加到 Menu
对象,而没有紧密耦合到算法或 Entry
的内部结构?
最佳答案
我是一名 Java 开发人员,我从未在 C++ 中使用过 TDD,但我也许可以像您上面提到的那样描述您想要测试的内容。
在经典 TDD 中,MenuPresenter
正如 Martin Fowler 在 Test Isolation 中所说,应该更像是一个小型集成测试。 .
In essence classic xunit tests are not just unit tests, but also mini-integration tests. As a result many people like the fact that client tests may catch errors that the main tests for an object may have missed, particularly probing areas where classes interact.
在经典 TDD 中尽可能使用真实对象和 Test Double如果测试的时候用真品不好意思MenuPresenter
.所以问问自己,当 Entry
时会发生什么预期效果?添加在 Menu
.测试 Menu
将添加标题为 Entry
的标题only 是没有意义的,你应该测试在 Entry
之后影响的行为是什么添加。假设一个Entry
添加将显示为标题 MenuItem
,因此您只需断言真实的 Menu
是否显示 MenuItem
的对象具有预期的标题。
确实,WhenSomeActionIsCalledShouldAddAnEntryContainingTitleToMenu
测试已经暴露 someAction
通过名称实现细节,并将测试与实现耦合 someAction
,另一方面,当您更改 someAction
的算法时测试将失败。您可以将测试添加为 displaysAnTitltedMenuItemInMenuWhenSomeActionIsCalledWithinATitle
.
如您所见,测试无论如何都会耦合到实现。我们唯一能做的就是让测试与实现的耦合尽可能低,这样,当实现发生变化时,我们只需更改一点测试即可。
如果您找到 Menu
是一个尴尬的,你可以使用 MenuSpy
相反,然后写一些 IntegrationContractTest在 MenuSpy
内& MenuImpl
.如您所见,测试使用 MenuSpy
与实际的 Menu
相比,与实现的耦合度更高一些,因为我们期望标题为 Entry
添加于 MenuSpy
不是 Menu
的影响在标题为 Entry
之后添加。
让MenuSpy
检查标题是否为 Entry
已添加,例如:
someAction(title);
menuSpy->hasReceivedATitledEntry(title);
或:您可能正在检查添加的 Entry
是否是 CheckableEntry
在getAddedEntryTitle
标题返回前的方法。
someAction(title);
EXPECT_TRUE(menuSpy->getAddedEntryTitle() == title);
关于c++ - 在工厂方法中测试对象的创建,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42908335/
我获得了一些源代码示例,我想测试一些功能。不幸的是,我在执行程序时遇到问题: 11:41:31 [linqus@ottsrvafq1 example]$ javac -g test/test.jav
我想测试ggplot生成的两个图是否相同。一种选择是在绘图对象上使用all.equal,但我宁愿进行更艰巨的测试以确保它们相同,这似乎是identical()为我提供的东西。 但是,当我测试使用相同d
我确实使用 JUnit5 执行我的 Maven 测试,其中所有测试类都有 @ExtendWith({ProcessExtension.class}) 注释。如果是这种情况,此扩展必须根据特殊逻辑使测试
在开始使用 Node.js 开发有用的东西之前,您的流程是什么?您是否在 VowJS、Expresso 上创建测试?你使用 Selenium 测试吗?什么时候? 我有兴趣获得一个很好的工作流程来开发我
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 3 年前。 基于示例here ,我尝试为我的
我正在考虑测试一些 Vue.js 组件,作为 Laravel 应用程序的一部分。所以,我有一个在 Blade 模板中使用并生成 GET 的组件。在 mounted 期间请求生命周期钩子(Hook)。假
考虑以下程序: #include struct Test { int a; }; int main() { Test t=Test(); std::cout<
我目前的立场是:如果我使用 web 测试(在我的例子中可能是通过 VS.NET'08 测试工具和 WatiN)以及代码覆盖率和广泛的数据来彻底测试我的 ASP.NET 应用程序,我应该不需要编写单独的
我正在使用 C#、.NET 4.7 我有 3 个字符串,即。 [test.1, test.10, test.2] 我需要对它们进行排序以获得: test.1 test.2 test.10 我可能会得到
我有一个 ID 为“rv_list”的 RecyclerView。单击任何 RecyclerView 项目时,每个项目内都有一个可见的 id 为“star”的 View 。 我想用 expresso
我正在使用 Jest 和模拟器测试 Firebase 函数,尽管这些测试可能来自竞争条件。所谓 flakey,我的意思是有时它们会通过,有时不会,即使在同一台机器上也是如此。 测试和函数是用 Type
我在测试我与 typeahead.js ( https://github.com/angular-ui/bootstrap/blob/master/src/typeahead/typeahead.js
我正在尝试使用 Teamcity 自动运行测试,但似乎当代理编译项目时,它没有正确完成,因为当我运行运行测试之类的命令时,我收到以下错误: fatal error: 'Pushwoosh/PushNo
这是我第一次玩 cucumber ,还创建了一个测试和 API 的套件。我的问题是在测试 API 时是否需要运行它? 例如我脑子里有这个, 启动 express 服务器作为后台任务 然后当它启动时(我
我有我的主要应用程序项目,然后是我的测试的第二个项目。将所有类型的测试存储在该测试项目中是一种好的做法,还是应该将一些测试驻留在主应用程序项目中? 我应该在我的主项目中保留 POJO JUnit(测试
我正在努力弄清楚如何实现这个计数。模型是用户、测试、等级 用户 has_many 测试,测试 has_many 成绩。 每个等级都有一个计算分数(strong_pass、pass、fail、stron
我正在尝试测试一些涉及 OkHttp3 的下载代码,但不幸失败了。目标:测试 下载图像文件并验证其是否有效。平台:安卓。此代码可在生产环境中运行,但测试代码没有任何意义。 产品代码 class Fil
当我想为 iOS 运行 UI 测试时,我收到以下消息: SetUp : System.Exception : Unable to determine simulator version for X 堆
我正在使用 Firebase Remote Config 在 iOS 上设置 A/B 测试。 一切都已设置完毕,我正在 iOS 应用程序中读取服务器端默认值。 但是在多个模拟器上尝试,它们都读取了默认
[已编辑]:我已经用 promise 方式更改了我的代码。 我正在写 React with this starter 由 facebook 创建,我是测试方面的新手。 现在我有一个关于图像的组件,它有
我是一名优秀的程序员,十分优秀!