我开始把头撞到墙上,但我完全不明白如何在间谍类上调用真正的方法。
长话短说,我正在监视我的测试类,以存根一个私有方法。然后我想调用测试类的real void方法,但它说
testedmethod是一个空方法,不能用返回值来存根它!
问题是,我不需要把它存根。我也尝试过doCallRealMethod(),没有用。
我正在使用静态编程语言和Android Studio为我的Android项目运行一些单元测试。我想测试以下类:
class MyClass {
fun persistDeviceData(deviceInfo: DeviceInfo, saveCallback: SaveCallback) {
val deviceObject = getDeviceObject()
// some setters from deviceInfo here
deviceObject.saveInBackground(callback)
}
// This method is created for unit testing purposes
private fun getDeviceObject(): MyDeviceObject{
return MyDeviceObject("someStringArgument")
}
}
这是测试课
import io.kotlintest.KTestJUnitRunner
import io.kotlintest.specs.BehaviorSpec
import junit.framework.Assert
import org.junit.runner.RunWith
import org.mockito.Mockito
import org.powermock.api.mockito.PowerMockito
import org.powermock.core.classloader.annotations.PrepareForTest
import org.powermock.modules.junit4.PowerMockRunner
import org.powermock.modules.junit4.PowerMockRunnerDelegate
@RunWith(PowerMockRunner::class)
@PowerMockRunnerDelegate(KTestJUnitRunner::class)
@PrepareForTest(MyClass::class)
class MyClassTest: BehaviorSpec(){
init {
val deviceObject = PowerMockito.mock(MyDeviceObject::class.java)
val myClassTest = PowerMockito.spy(MyClass())
// Mocking private method call
PowerMockito.doReturn(deviceObject).`when`(testedRepo,
PowerMockito.method(
MyClass::class.java,
"getDeviceObject"))
val a = SaveCallback { // Callback handling here }
// Calling REAL method of spy class. Here it fails
myClassTest.persistDeviceData(DeviceInfo(), a)
Assert.assertTrue(true)
}
}
在下面一行调用real方法时,测试失败
MyClassTest.persistDeviceData(DeviceInfo(), a)
这是错误堆栈跟踪
org.mockito.exceptions.misusing.Cannot StubVoidmetodwith ReportnValue:'坚持设备数据'是一个空方法,它不能用一个返回值来存根!空通常用Throwable来存根:doThrow(异常)。当(mock)。一些Voidmethod();如果你需要设置空方法什么也不做,你可以使用:do没什么()。当(mock)。一些Voidmethod();有关更多信息,请查看Mockito.do没什么()的javadocs。
如果你不确定为什么会出现上述错误,请继续阅读。由于语法的性质,上述问题可能会出现,因为:1。您尝试存根的方法已重载。确保调用的是正确的重载版本。2.在考试的某个地方,你正在截取最后的方法。抱歉,Mockito不验证/stub final方法。3.间谍使用when(spy.foo())进行存根。then()语法。使用doReturn | Throw()方法系列,对存根间谍更安全。更多关于Mockito的javadocs。spy()方法。4.不支持对非公共父类声明的模拟方法。
at MyClassTest.<init>(MyClass.kt:46)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
at java.lang.Class.newInstance(Class.java:442)
at io.kotlintest.KTestJUnitRunner.<init>(KTestJUnitRunner.kt:9)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
at org.powermock.reflect.internal.WhiteboxImpl.createInstance(WhiteboxImpl.java:1414)
at org.powermock.reflect.internal.WhiteboxImpl.invokeConstructor(WhiteboxImpl.java:1262)
at org.powermock.reflect.Whitebox.invokeConstructor(Whitebox.java:497)
at org.powermock.modules.junit4.internal.impl.DelegatingPowerMockRunner$1.call(DelegatingPowerMockRunner.java:101)
at org.powermock.modules.junit4.internal.impl.DelegatingPowerMockRunner$1.call(DelegatingPowerMockRunner.java:97)
at org.powermock.modules.junit4.internal.impl.DelegatingPowerMockRunner.withContextClassLoader(DelegatingPowerMockRunner.java:132)
at org.powermock.modules.junit4.internal.impl.DelegatingPowerMockRunner.createDelegate(DelegatingPowerMockRunner.java:96)
at org.powermock.modules.junit4.internal.impl.DelegatingPowerMockRunner.<init>(DelegatingPowerMockRunner.java:64)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
at org.powermock.modules.junit4.common.internal.impl.JUnit4TestSuiteChunkerImpl.createDelegatorFromClassloader(JUnit4TestSuiteChunkerImpl.java:165)
at org.powermock.modules.junit4.common.internal.impl.JUnit4TestSuiteChunkerImpl.createDelegatorFromClassloader(JUnit4TestSuiteChunkerImpl.java:47)
at org.powermock.tests.utils.impl.AbstractTestSuiteChunkerImpl.createTestDelegators(AbstractTestSuiteChunkerImpl.java:107)
at org.powermock.modules.junit4.common.internal.impl.JUnit4TestSuiteChunkerImpl.<init>(JUnit4TestSuiteChunkerImpl.java:69)
at org.powermock.modules.junit4.common.internal.impl.AbstractCommonPowerMockRunner.<init>(AbstractCommonPowerMockRunner.java:36)
at org.powermock.modules.junit4.PowerMockRunner.<init>(PowerMockRunner.java:34)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
at org.junit.internal.builders.AnnotatedBuilder.buildRunner(AnnotatedBuilder.java:104)
at org.junit.internal.builders.AnnotatedBuilder.runnerForClass(AnnotatedBuilder.java:86)
at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59)
at org.junit.internal.builders.AllDefaultPossibilitiesBuilder.runnerForClass(AllDefaultPossibilitiesBuilder.java:26)
at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59)
at org.junit.internal.requests.ClassRequest.getRunner(ClassRequest.java:33)
at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:49)
at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47)
at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242)
at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70)
回答我自己的问题——我错误地使用了PowerMockito的。when()方法。以下是有效的代码:
@RunWith(PowerMockRunner::class)
@PrepareForTest(MyClass::class, DeviceObject::class)
class DeviceRepositoryImplTest{
private val testedRepo = PowerMockito.spy(MyClass())
private val deviceObject = PowerMockito.mock(DeviceObject())
@Test
fun persistDeviceData_ok(){
// Mocking private method
PowerMockito.`when`<ParseObject>(testedRepo,
PowerMockito.method(
MyClass::class.java,
"getDeviceObject")).withNoArguments().thenReturn(deviceObject)
// Creating callback for tested method
val callback = SaveCallback {
...
}
...
testedRepo.persistDeviceData(DeviceInfo(), callback)
}
这是我的控制器: 这是我访问http://localhost:8080/area/1时得到的: 无法转换“java”类型的值。lang.String'转换为必需的类型'int';嵌套的例外是java。lang.NumberFormatException:对于输入字符串:“asd3333”] 我测试了这个随机返回,只是为了显示发生了什么...该方法首先用请求中的@PathVariable=1调用,然
本文向大家介绍javascript实现方法调用与方法触发小结,包括了javascript实现方法调用与方法触发小结的使用技巧和注意事项,需要的朋友参考一下 在js中,this关键字是一个比较让人有意思的东西,但是它的指向经常让初学者摸不着头脑。 其实要理解这个关键字,需要理清两个问题——“方法的调用和方法的触发” 下面先看一段代码 20行打印出window对象,这个很容易理解,但是21
我有一个类,它有两个方法。我想模拟这个类,然后模拟第一个方法,但不是第二个。 例如。 单元测试代码: 奇怪的是m2没有被调用。 我错过什么了吗?
本文向大家介绍javascript实用方法总结,包括了javascript实用方法总结的使用技巧和注意事项,需要的朋友参考一下 引言: 本章没有深奥的讲解js一些底层原理,比如this指针、作用域、原型啦,涉及的都是一些有利于平时开发时简化代码,提高执行效率,或者说可以当做一种经验方法来使用,篇幅都不长,小步快跑的让你阅读完整篇文章,体验编程的快乐。 获取两个区间之内随机数 随机返回一个 正
我们有一个用例,我们必须从Xlst模板调用实例方法。我们使用的是Saxon-He9.6版本。穿过了这个堆栈溢出的柱子。我们尝试用Java对象作为参数pssing XML transformer,然后更新模板以调用该实例方法。但它给出了javax.xml.Transform.TransformerConfigurationException。 如果我们可以使用Saxon HE从XSLT模板中调用实例
问题内容: 如何在不返回值的模板中执行功能?这是示例: 在play.golang.org中看到此代码 我知道模板中的逻辑不应该太多,但是对无返回值的运行函数的无知对我来说似乎是一个有趣的问题。 问题答案: Go中的模板与其他语言(例如PHP)中的模板不同。使用为您的模板创建自定义功能。 或者,尝试使用游乐场版本。