- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为 MVP 项目的演示者编写单元测试。
class SplashPresenter {
override fun onAttach() {
if (dataManager.getAppLaunchFirstTime()) {
onAppOpenFirstTime()
} else {
// Other logic...
}
}
@VisibleForTesting
fun onAppOpenFirstTime() {
dataManager.setAppLaunchFirstTime(false)
splashView.openLoginScreen()
// May be I will add more functionalities in the future...
}
}
这里我们有2种方法来编写单元测试。
第一种方法
直接验证会发生什么:openLoginScreen()
& setAppLaunchFirstTime(false)
。不关心他们将如何被调用。
@Test
fun onAttachTest_appLaunchFirstTime() {
Mockito.`when`(dataManager.getAppLaunchFirstTime()).thenReturn(true)
splashPresenter.onAttach()
verify(dataManager).setAppLaunchFirstTime(false)
verify(splashView).openLoginScreen()
}
第二种方法
我们使用 spy()
来验证私有(private)内部方法 onAppOpenFirstTime()
是否会被调用。然后为 onAppOpenFirstTime()
编写另一个单独的测试。
@Test
fun onAttachTest_appLaunchFirstTime() {
`when`(dataManager.getAppLaunchFirstTime()).thenReturn(true)
val spyPresenter = Mockito.spy(splashPresenter)
spyPresenter.onAttach()
verify(spyPresenter).onAppOpenFirstTime()
}
@Test
fun onAppOpenFirstTimeTest() {
splashPresenter.onAppOpenFirstTime()
verify(dataManager).setAppLaunchFirstTime(false)
verify(splashView).openLoginScreen()
}
那么哪种方法更好呢?在将来扩展功能时,哪种方法将使项目更易于测试?
我们需要为私有(private)内部方法编写单元测试吗?
最佳答案
(您已经问过哪种方法会使项目更易于测试,但可测试性是被测系统的一个属性。然而,本例中测试套件的显着属性是测试代码维护的努力。)
在您的特定示例中,第二种方法使您的测试不必要地依赖于可能会更改的实现细节:您可能重命名onAppOpenFirstTime
,将其拆分为更多辅助函数,甚至删除它并将其内联到 onAttach
中。在所有这些变更场景中,第二种方法将导致额外的维护工作以保持测试套件正常工作。
不过,我强调这里不需要依赖onAppOpenFirstTime
。这是因为采用第二种方法没有任何好处:第一种方法似乎能够找到与第二种方法相同的错误,第一种方法中的测试与第二种方法一样容易设置(甚至更容易)等等上。
如果你只想知道如何解决所描述的特定问题,你可以停止阅读这里。然而,在其他情况下,情况可能有所不同。我在下面添加评论,因为我不是经常说的口头禅“不要测试私有(private)方法”的提倡者。
尝试使单元测试套件完全独立于实现细节可能会导致测试套件效率低下 - 也就是说,测试套件不适合查找所有可能发现的错误。而且,发现错误是测试的主要目标之一(请参阅 Myers、Badgett、Sandler:软件测试的艺术,或 Beizer:软件测试技术等)。
错误最终出现在实现中。不同的实现会有不同的bug。因此,尝试拥有一个与实现无关的测试套件可能无法找到错误。
考虑实现 Fibonacci 函数的不同方法:作为迭代/递归函数、封闭形式表达式 (Moivre/Binet)、查找表:每种实现都会带来不同的潜在错误。单元测试是test pyramid底部的测试方法,并且所有更高级别的测试(集成或系统测试)不太适合在实现细节中查找错误。
因此,最好的方法是拥有尽可能多的独立于实现的有用单元测试。此外,您可能需要额外的单元测试,旨在发现所选实现中的潜在错误。最后,您的测试套件可能是两者的混合体:独立于实现的测试和特定于实现的测试。
依赖于实现的测试将更加维护密集,因此对于每一个你都应该有一个理由,例如检测特定于实现的潜在错误。特定于实现的测试本身并不是坏事,但不要在不必要的情况下使用它们。而且,实现方面越不稳定,您就越应该避免让您的测试依赖于它。
参见 Meszaros Principles of Test Automation: Ensure Commensurate Effort
关于android - 为 Presenter 的私有(private)方法编写单元测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56504337/
我最近在/ drawable中添加了一些.gifs,以便可以将它们与按钮一起使用。这个工作正常(没有错误)。现在,当我重建/运行我的应用程序时,出现以下错误: Error: Gradle: Execu
Android 中有返回内部存储数据路径的方法吗? 我有 2 部 Android 智能手机(Samsung s2 和 s7 edge),我在其中安装了一个应用程序。我想使用位于这条路径中的 sqlit
这个问题在这里已经有了答案: What's the difference between "?android:" and "@android:" in an android layout xml f
我只想知道 android 开发手机、android 普通手机和 android root 手机之间的实际区别。 我们不能从实体店或除 android marketplace 以外的其他地方购买开发手
自Gradle更新以来,我正在努力使这个项目达到标准。这是一个团队项目,它使用的是android-apt插件。我已经进行了必要的语法更改(编译->实现和apt->注释处理器),但是编译器仍在告诉我存在
我是android和kotlin的新手,所以请原谅要解决的一个非常简单的问题! 我已经使用导航体系结构组件创建了一个基本应用程序,使用了底部的导航栏和三个导航选项。每个导航选项都指向一个专用片段,该片
我目前正在使用 Facebook official SDK for Android . 我现在正在使用高级示例应用程序,但我不知道如何让它获取应用程序墙/流/状态而不是登录的用户。 这可能吗?在那种情
我在下载文件时遇到问题, 我可以在模拟器中下载文件,但无法在手机上使用。我已经定义了上网和写入 SD 卡的权限。 我在服务器上有一个 doc 文件,如果用户单击下载。它下载文件。这在模拟器中工作正常但
这个问题在这里已经有了答案: What is the difference between gravity and layout_gravity in Android? (22 个答案) 关闭 9
任何人都可以告诉我什么是 android 缓存和应用程序缓存,因为当我们谈论缓存清理应用程序时,它的作用是,缓存清理概念是清理应用程序缓存还是像内存管理一样主存储、RAM、缓存是不同的并且据我所知,缓
假设应用程序 Foo 和 Eggs 在同一台 Android 设备上。任一应用程序都可以获取设备上所有应用程序的列表。一个应用程序是否有可能知道另一个应用程序是否已经运行以及运行了多长时间? 最佳答案
我有点困惑,我只看到了从 android 到 pc 或者从 android 到 pc 的例子。我需要制作一个从两部手机 (android) 连接的 android 应用程序进行视频聊天。我在想,我知道
用于使用 Android 以编程方式锁定屏幕。我从 Stackoverflow 之前关于此的问题中得到了一些好主意,并且我做得很好,但是当我运行该代码时,没有异常和错误。而且,屏幕没有锁定。请在这段代
文档说: android:layout_alignParentStart If true, makes the start edge of this view match the start edge
我不知道这两个属性和高度之间的区别。 以一个TextView为例,如果我将它的layout_width设置为wrap_content,并将它的width设置为50 dip,会发生什么情况? 最佳答案
这两个属性有什么关系?如果我有 android:noHistory="true",那么有 android:finishOnTaskLaunch="true" 有什么意义吗? 最佳答案 假设您的应用中有
我是新手,正在尝试理解以下 XML 代码: 查看 developer.android.com 上的文档,它说“starStyle”是 R.attr 中的常量, public static final
在下面的代码中,为什么当我设置时单选按钮的外观会发生变化 android:layout_width="fill_parent" 和 android:width="fill_parent" 我说的是
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
假设我有一个函数 fun myFunction(name:String, email:String){},当我调用这个函数时 myFunction('Ali', 'ali@test.com ') 如何
我是一名优秀的程序员,十分优秀!