- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我经常看到验证的方法与 Mockito
中模拟的方法相同(如下例)。在这些情况下调用 Mockito.verify()
有什么额外的好处吗?
//mock method
FooService fs = mock(FooService.class);
when(fs.getFoo()).thenReturn("foo");
//method under test
fs.doSomething();
//verify method
verify(fs).getFoo();
如果未调用 fs.getFoo()
,该方法将失败。那么为什么要调用verify
呢?如果您需要在验证中使用 ArgumentCaptor
断言参数,我看到了好处;除了 ArgumentCaptor 案例之外,是否只是不必要的?
最佳答案
Mockito 文档反复说它通常是多余的。这在 verify(T)
's Javadoc 中逐字出现作为 Mockito's main class Javadoc section 2 中代码块中的多个单行注释:
Although it is possible to verify a stubbed invocation, usually it's just redundant.If your code cares what
get(0)
returns, then something else breaks (often even beforeverify()
gets executed).If your code doesn't care whatget(0)
returns, then it should not be stubbed. Not convinced? See here.
请注意,最初链接的文章“Asking and Telling”是由 Mockito 创始人 Szczepan Faber 撰写的,可以认为是 Mockito 设计中的权威文档。摘自该帖子:
Do I really have to repeat the same expression? After all, stubbed interactions are verified implicitly. The execution flow of my own code does it completely for free. Aaron Jensen also noticed that:
If you’re verifying you don’t need to stub unless of course that method returns something that is critical to the flow of your test (or code), in which case you don’t really need to verify, because the flow would have verified.
简单回顾一下:没有重复的代码。
但是,如果一个有趣的交互具有询问和讲述的特征怎么办?我是否必须在 stub() 和 verify() 中重复交互?我最终会得到重复的代码吗?并不真地。在实践中:如果我 stub ,那么它是免费验证的,所以我不验证。 如果我验证,那么我不关心返回值,所以我不 stub 。无论哪种方式,I don’t repeat myself .不过从理论上讲,我可以想象一种罕见的情况,我确实验证了 stub 交互,例如确保 stub 交互恰好发生了 n 次。但这是行为的另一个方面,显然是一个有趣的方面。因此,我想说清楚一点,我非常乐意牺牲一行额外的代码……
最近版本的 Mockito(自发布此问答以来发布)添加了一些额外的功能 allow或 default to更严格的 mock 风格。尽管如此,普遍的期望是通过仅验证您无法通过断言或成功完成测试确认的内容来避免脆弱性。
总的来说,Mockito 的设计是让测试尽可能灵活,编码不是针对实现,而是针对您正在测试的方法的规范。尽管您偶尔会看到方法调用作为函数规范的一部分(“向服务器提交 RPC”或“立即调用传递的 LoginCallback”),但您更有可能希望验证可以执行的后置条件从 stub 中推断:检查 getFoo
是否被调用并不是规范的一部分,只要您 stub getFoo
返回“foo”并且数据存储包含一个其相应属性设置为“foo”的单个对象。
简而言之,仅显式验证无法从精心设计的 stub 和后置条件断言中隐含的交互被认为是良好的 Mockito 风格。它们可能是对其他方面无法衡量的副作用(记录代码、线程执行器、ArgumentCaptors、多方法调用、回调函数)的良好调用,但通常不应应用于 stub 交互。
关于java - 是否不需要验证与 Mockito 中模拟的方法相同的方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35262529/
我正在尝试用 C 语言编写一个使用 gstreamer 的 GTK+ 应用程序。 GTK+ 需要 gtk_main() 来执行。 gstreamer 需要 g_main_loop_run() 来执行。
我已经使用 apt-get 安装了 opencv。我得到了以下版本的opencv2,它工作正常: rover@rover_pi:/usr/lib/arm-linux-gnueabihf $ pytho
我有一个看起来像这样的 View 层次结构(基于其他答案和 Apple 的使用 UIScrollView 的高级 AutoLayout 指南): ScrollView 所需的2 个步骤是: 为 Scr
我尝试安装 udev。 udev 在 ./configure 期间给我一个错误 --exists: command not found configure: error: pkg-config and
我正在使用 SQLite 3。我有一个表,forums,有 150 行,还有一个表,posts,有大约 440 万行。每个帖子都属于一个论坛。 我想从每个论坛中选择最新帖子的时间戳。如果我使用 SEL
使用 go 和以下包: github.com/julienschmidt/httprouter github.com/shwoodard/jsonapi gopkg.in/mgo.v2/bson
The database仅包含 2 个表: 钱包(100 万行) 事务(1500 万行) CockroachDB 19.2.6 在 3 台 Ubuntu 机器上运行 每个 2vCPU 每个 8GB R
我很难理解为什么在下面的代码中直接调用 std::swap() 会导致编译错误,而使用 std::iter_swap 编译却没有任何错误. 来自 iter_swap() versus swap() -
我有一个非常简单的 SELECT *用 WHERE NOT EXISTS 查询条款。 SELECT * FROM "BMAN_TP3"."TT_SPLDR_55E63A28_59358" SELECT
我试图按部分组织我的 .css 文件,我需要从任何文件访问文件组中的任何类。在 Less 中,我可以毫无问题地创建一个包含所有文件导入的主文件,并且每个文件都导入主文件,但在 Sass 中,我收到一个
Microsoft.AspNet.SignalR.Redis 和 StackExchange.Redis.Extensions.Core 在同一个项目中使用。前者需要StackExchange.Red
这个问题在这里已经有了答案: Updating from Rails 4.0 to 4.1 gives sass-rails railties version conflicts (4 个答案) 关
我们有一些使用 Azure DevOps 发布管道部署到的现场服务器。我们已经使用这些发布管道几个月了,没有出现任何问题。今天,我们在下载该项目的工件时开始出现身份验证错误。 部署组中的节点显示在线,
Tip: instead of creating indexes here, run queries in your code – if you're missing any indexes, you
你能解释一下 Elm 下一个声明中的意思吗? (=>) = (,) 我在 Elm architecture tutorial 的例子中找到了它 最佳答案 这是中缀符号。实际上,这定义了一个函数 (=>
我需要一个 .NET 程序集查看器,它可以显示低级详细信息,例如元数据表内容等。 最佳答案 ildasm 是 IL 反汇编程序,具有低级托管元数据 token 信息。安装 Visual Studio
我有两个列表要在 Excel 中进行比较。这是一个很长的列表,我需要一个 excel 函数或 vba 代码来执行此操作。我已经没有想法了,因此转向你: **Old List** A
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想要改善这个问题吗?更新问题,以便将其作为on-topi
我正在学习 xml 和 xml 处理。我无法很好地理解命名空间的存在。 我了解到命名空间帮助我们在 xml 中分离相同命名的元素。我们不能通过具有相同名称的属性来区分元素吗?为什么命名空间很重要或需要
我搜索了 Azure 文档、各种社区论坛和 google,但没有找到关于需要在公司防火墙上打开哪些端口以允许 Azure 所有组件(blob、sql、compute、bus、publish)的简洁声明
我是一名优秀的程序员,十分优秀!