如何在单元测试中使用android依赖项?

时间:2019-05-26 12:51:47

标签: android unit-testing kotlin mockito

我目前正在尝试TDD,但无法了解如何在单元测试中使用android依赖项。

我想解析PONS API对对象的JSON响应。 为了测试我的Jsonparser,我试图创建一个间谍间谍,或者只是创建一个JsonReader的普通实例android.utils.JsonReader,然后将其传递给解析器。


@Mock
private var reader : JsonReader = JsonReader(BufferedReader(FileReader(fileName)))


@Before
fun setUp(){
    MockitoAnnotations.initMocks(this)
}

@Test
fun parseTest() {

    val response = ResponseParser.parse(reader)

    val entry : response.Entry = response.getEntry(0)

    assertThat(entry.strings_displayed[0].get(0).first, `is`("Haus (Wohnhaus, Heim)"))
    assertThat(entry.strings_displayed[0].get(0).second, `is`("casa"))
    }

但是我的尝试都没有产生期望的输出。到目前为止,我无法使用JsonReader类。我得到的只是该错误消息(原因已被谷歌搜索)

java.lang.RuntimeException: Method beginObject in android.util.JsonReader not mocked. See http://g.co/androidstudio/not-mocked for details.
at android.util.JsonReader.beginObject(JsonReader.java)
at com.huckebrink.remindyct.Data.PONSRequestParser$Companion.readJsonString(PONSRequestParser.kt:23)
at com.huckebrink.remindyct.Data.PONSRequestParser$Companion.parse(PONSRequestParser.kt:13)
at com.huckebrink.remindyct.ParsingUnitTest.parseTest(ParsingUnitTest.kt:47)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68)
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)

1 个答案:

答案 0 :(得分:1)

好吧,我的建议是尝试在不依赖Android框架的情况下保持单元测试级别,如果您只能在单元级别使用Kotlin pure进行测试,而在集成级别保留更复杂的测试,这将使一切变得容易。

有时,将应用程序耦合起来并不是一件容易的事,因此,您可以使用Robolectric之类的库来使Android Framework在单元测试中部分起作用。

搜索:“机器人单元测试”以获取示例。祝你好运

更新:

摘自Android文档https://developer.android.com/training/testing/unit-testing

  

本地测试:仅在本地计算机上运行的单元测试。这些测试被编译为在Java虚拟机(JVM)上本地运行,以最大程度地缩短执行时间。如果您的测试依赖于Android框架中的对象,我们建议使用Robolectric。对于依赖于您自己的依赖项的测试,请使用模拟对象来模拟依赖项的行为。

更新2:

无论如何,JSON解析应该是测试的测试/集成级别的一部分,如果您希望依赖项在测试目录上使用JsonParing,则可以添加:

testCompile ‘org.json:json:20140107’