• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

IOS毒蛇: How protocol helps in Unit Testing?

[复制链接]
菜鸟教程小白 发表于 2022-12-12 12:34:02 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我对 VIPER 架构中协议(protocol)的好处有点困惑。 我了解 DI(依赖注入(inject))是通过协议(protocol)实现的,并有助于避免对象之间的直接依赖关系 - 我同意。

但我从使用的角度来看真正的好处,一个例子可能是 - 特别是协议(protocol)如何帮助在单元测试中受益(测试交互器部分)。

我们不能通过方法回调的 using block 来实现相同的效果吗? 希望有人可以通过一些示例从使用角度帮助我理解

干杯



Best Answer-推荐答案


使用回调,例如从 Interactor 到 Presenter,可能会使 Presenter 的测试变得更加困难。

在为 Presenter 如何处理输入(从 Interactor 发送)编写测试时,您的测试必须在 Presenter 上调用一些方法,这会导致 Presenter 对 Interactor 进行调用,这会导致 Interactor 发送数据给演示者。

通过让 Presenter 实现由 Interactor 定义的协议(protocol),您的测试可以直接在 Presenter 上调用适当的输入法。

就声明协议(protocol)而言,我以模拟角色的风格练习 TDD,而不是对象 (http://www.jmock.org/oopsla2004.pdf)。这些协议(protocol)通过关注对象的作用(其角色)而不是它的作用方式来帮助提供更好的抽象。

协议(protocol)本身对单元测试没有什么值(value)。您的单元测试将为被测系统的依赖项提供测试替身(http://martinfowler.com/bliki/TestDouble.html)。即使您将依赖项公开为具体类,您仍然可以为您的测试创建测试替身。

在 Objective-C 中,您可以使用诸如 OCMock (http://ocmock.org) 或 OCMockito (https://github.com/jonreid/OCMockito) 之类的模拟库来创建具体类的 stub 、 spy 或模拟。

在 Swift 中,您可以通过子类化每个用作依赖项的具体类来创建测试替身。

简而言之,协议(protocol)不是用来简化单元测试,而是在更高的抽象层次上描述应用程序的功能。

下面是一个例子,说明抽象协议(protocol)在事后是如何有益的:

我创建了一个协议(protocol)来表示用户可以在屏幕上执行的操作,例如ProfileUserActions,具有 changeNamechangeAddress 等操作。 Presenter 实现了 ProfileUserActions,而 View 接受了一个 ProfileUserActions 作为依赖项。当用户点击屏幕上的按钮时, View 会向其 userActions 对象发送适当的消息。

当我想添加分析时,我能够创建一个新的、独立的 ProfileAnalytics 类,该类还实现了 ProfileUserActions。我在 View 和 Presenter 之间插入了分析对象,这允许应用程序捕获分析,而无需修改 View 或 Presenter。

关于IOS毒蛇: How protocol helps in Unit Testing?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41198279/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap