gpt4 book ai didi

android - 用于测试 rxjava 的书面单元测试,但不确定我的单元测试是否正在测试所有内容

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:10:32 28 4
gpt4 key购买 nike

Android Studio 3.4

我正在测试以下方法。基本上,这个测试所做的是发出一个请求,它将返回一个 LoginResponseEntity。将被映射并返回 Single<LoginResponse>

 override fun loginUserPost(username: String, password: String, uniqueIdentifier: String, deviceToken: String, apiToken: String) : Single<LoginResponse> {
val loginRequestEntity = LoginRequestEntity(username, password, uniqueIdentifier, deviceToken)
return loginAPIService.loginUserPost(loginRequestEntity, apiToken)
.map {
loginResponseDomainMapper.map(it)
}
}

我写的测试用例有效,但我认为这并没有完全测试这个方法。

     @Test
fun `should return LoginResponse`() {
val loginRequestEntity = LoginRequestEntity("username", "password", "uniqueidentifier", "devicetoken")
val loginResponse = LoginResponse("token", createUser(), emptyList(), emptyList())
val loginResponseEntity = LoginResponseEntity("token", createUserEntity(), emptyList(), emptyList())

whenever(loginAPIService.loginUserPost(loginRequestEntity, "apitoken")).thenReturn(Single.just(loginResponseEntity))

loginServiceImp.loginUserPost("username", "password", "uniqueidentifier", "devicetoken", "apitoken")
.test()
.assertValue(loginResponse)

verify(loginAPIService).loginUserPost(loginRequestEntity, "apitoken")
}

private fun createUser() =
User(
"id",
"email",
"firstname",
"lastname",
"phone",
"address",
"dob",
"customer",
listOf("enterpriseids"),
listOf("vendorids"))

private fun createUserEntity() =
UserEntity(
"id",
"email",
"firstname",
"lastname",
"phone",
"address",
"dob",
"customer",
listOf("enterpriseids"),
listOf("vendorids"))
}

还有什么我可以做的来测试这个方法。我应该测试 .map{loginResponseDomainMapper.map(it) 吗?这个方法的一部分?

最佳答案

这是一个非常小的方法,不包含很多要测试的东西。两个外部依赖项(loginAPIServiceloginResponseDomainMapper)进一步减少了要测试的内容。

所以,

1) loginResponseDomainMapper 不是测试方法的一部分,也应该被模拟。

2)你要明白,这里应该测试什么。

  • 首先:检查 LoginRequestEntity 是否正确构造并传递给 loginUserPost 方法。这是通过 verify(loginAPIService).loginUserPost(loginRequestEntity, "apitoken") 调用完成的。此外,您可以使用 ArgumentCaptor .
  • 第二:loginUserPost 方法的输出已正确传递给 loginResponseDomainMapper.map 方法。这可以像以前一样通过额外的 verify 调用来完成。
  • 第三:正确返回了 map 方法的输出。这是通过 assertValue 调用完成的。

所以,您只是想验证数据流是否正确,并且在执行过程中没有被外星人或类似的东西修改过。

3) 负面测试。也没有多少事情会出错。如果loginUserPost没有@NotNull注解,你最好处理这个函数的null结果。
另外,如果请求不正确怎么办?密码错误,或者 apitoken 已过期?我相信这不会导致可悲的后果,但你应该考虑一下。

关于android - 用于测试 rxjava 的书面单元测试,但不确定我的单元测试是否正在测试所有内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53945445/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com