- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以,我只是在编写简单的测试。问题是测试运行器运行真正的“存储库”类代码而不是模拟代码......您知道为什么我可以在这方面获得异常(exception)吗?
测试类
class SingInFacebookPresenterTest {
@Mock
private lateinit var view: SignInFacebookContract.View
@Mock
private lateinit var repository: Repository
@Captor
private lateinit var callback: ArgumentCaptor<RepositoryCallback.FacebookLoginImp>
private lateinit var presenter: SingInFacebookPresenter
private val serverToken = "token"
@Before
fun init() {
MockitoAnnotations.initMocks(this)
presenter = SingInFacebookPresenter(MockContext(), repository, view)
}
@Test
fun facebook_login_success() {
//Given
val token = "token"
val serverToken = "server token"
presenter.loginViaFacebook(token)
//When
verify(repository).loginViaFacebook(token, callback.capture())
callback.value.onSuccess(serverToken)
//Then
verify(view).success(serverToken)
}
主持人
class SingInFacebookPresenter(var context: Context, var repository: Repository, var view: SignInFacebookContract.View): SignInFacebookContract.Presenter {
public override fun loginViaFacebook(token: String) {
repository.loginViaFacebook(token, object : RepositoryCallback.FacebookLoginImp {
override fun onSuccess(token: String) {
view.success(token)
}
override fun onFailure() {
view.onFailure()
}
})
}
存储库
open class Repository(context: Context) {
init {
ApiHelper(context)
}
private var facebookLoginPresenterCallback: RepositoryCallback.FacebookLoginImp? = null
fun loginViaFacebook(token: String, facebookLoginPresenterCallback: RepositoryCallback.FacebookLoginImp?) {
// this.facebookLoginPresenterCallback = facebookLoginPresenterCallback
val signInResponse = ApiHelper.signInViaFacebook(token)
// signInResponse.enqueue(signInFacebookCallback)
signInResponse.enqueue(object : Callback<SignInResponse> {
override fun onResponse(call: Call<SignInResponse>?, response: Response<SignInResponse>?) {
if (response!!.isSuccessful) {
val token = response.body()?.token ?: return
facebookLoginPresenterCallback?.onSuccess(token)
return
}
facebookLoginPresenterCallback?.onFailure()
}
override fun onFailure(call: Call<SignInResponse>?, t: Throwable?) {
facebookLoginPresenterCallback?.onFailure()
}
})
}
private val signInFacebookCallback = object : Callback<SignInResponse> {
override fun onResponse(call: Call<SignInResponse>?, response: Response<SignInResponse>?) {
if (response!!.isSuccessful) {
val token = response.body()?.token ?: return
facebookLoginPresenterCallback?.onSuccess(token)
return
}
facebookLoginPresenterCallback?.onFailure()
}
override fun onFailure(call: Call<SignInResponse>?, t: Throwable?) {
facebookLoginPresenterCallback?.onFailure()
}
}
}
异常(exception):
Exception in thread "OkHttp Dispatcher" java.lang.NoSuchMethodError: okhttp3.internal.Platform.log(Ljava/lang/String;)V
at okhttp3.logging.HttpLoggingInterceptor$Logger$1.log(HttpLoggingInterceptor.java:109)
at okhttp3.logging.HttpLoggingInterceptor.intercept(HttpLoggingInterceptor.java:157)
at okhttp3.RealCall$ApplicationInterceptorChain.proceed(RealCall.java:190)
at okhttp3.RealCall.getResponseWithInterceptorChain(RealCall.java:163)
at okhttp3.RealCall.access$100(RealCall.java:30)
at okhttp3.RealCall$AsyncCall.execute(RealCall.java:127)
at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
Exception in thread "OkHttp Dispatcher" java.lang.NoSuchMethodError: okhttp3.internal.Platform.log(Ljava/lang/String;)V
at okhttp3.logging.HttpLoggingInterceptor$Logger$1.log(HttpLoggingInterceptor.java:109)
at okhttp3.logging.HttpLoggingInterceptor.intercept(HttpLoggingInterceptor.java:157)
at okhttp3.RealCall$ApplicationInterceptorChain.proceed(RealCall.java:190)
at okhttp3.RealCall.getResponseWithInterceptorChain(RealCall.java:163)
at okhttp3.RealCall.access$100(RealCall.java:30)
at okhttp3.RealCall$AsyncCall.execute(RealCall.java:127)
at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
org.mockito.exceptions.base.MockitoException:
No argument value was captured!
You might have forgotten to use argument.capture() in verify()...
...or you used capture() in stubbing but stubbed method was not called.
Be aware that it is recommended to use capture() only with verify()
Examples of correct argument capturing:
ArgumentCaptor<Person> argument = ArgumentCaptor.forClass(Person.class);
verify(mock).doSomething(argument.capture());
assertEquals("John", argument.getValue().getName());
最佳答案
好吧,这是一个很好的。这是我发现的:
测试代码不是问题,Mockito 出于某种原因创建了 Repository
的真实(?)实例。或者至少无法在某处拦截方法调用?
无论如何,这是一个完全精简的示例,它重现了 org.mockito:mockito-core:2.7.11
的问题:
open class Greeter {
fun hello() = "hello world"
}
class MockitoJavaExample {
@Test
fun test() {
val greeter: Greeter = mock()
println(greeter.hello()) // prints "hello world" which it shouldn't
}
}
我对 Mockito 的内部结构不够熟悉,无法告诉您这是如何发生的,但是切换到使用 mockito-inline
,一种不同的模拟方法解决了这个问题。它还使您能够在 Kotlin 中模拟非 open
类,无论如何您可能都想要这样,这样您就不必为了测试而打开类进行扩展。使用此方法,无论类是否打开,您都可以正确地获得函数返回的 null
,因此它不使用真正的实现。
您可以使用 compile 'org.mockito:mockito-inline:2.7.11'
而不是 -core
版本切换到 Mockito 的内联版本。
关于安卓。 Mockito 使用真实对象而不是模拟对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42767781/
我正在寻找x86 Assembly中pow(real, real)的实现。我也想了解算法的工作原理。 最佳答案 只需将其计算为2^(y*log2(x))即可。 有一个x86指令FYL2X计算y *
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
风格指南的最后一点 http://www.python.org/dev/peps/pep-0008 读... 不要使用 == 将 bool 值与 True 或 False 进行比较。 为什么? 编辑只
我似乎无法完成这件事。我仍然在我的日志中看到 cloudflare IP。目前,我有一个负载均衡器,它位于 Cloudflare 后面。 目前,这是与 forwardfor 相关的块: opt
此代码行选择任何类名不是“id”和“quantity”的 div 内的所有子输入:: $("div.item > div:not(.id,.quantity) > :input").live("key
我在测试真实产品时遇到错误。当我单击购买按钮时,出现错误“此版本的应用程序未配置为市场计费”。 我用这个例子https://github.com/robotmedia/AndroidBillingLi
到目前为止我能找到的所有答案都建议调用 omp_set_num_threads。虽然在大多数情况下这是一个正确的答案,但它对我不起作用。在内部,调用 omp_set_num_threads 会导致创建
假设我有 3 个显示器。如何仅通过其索引获取第二个句柄? EnumDisplayMonitors() 不会工作,因为它也枚举了伪设备,而 EnumDisplayDevices() 没有给我句柄。 最佳
我一直在尝试制作一个简单的小游戏来测试我的逻辑,这是一个简单的迷宫,它很丑,而且到目前为止很糟糕。 引擎工作得很好,考虑到迷宫已经存在(矩阵),它甚至可以愉快,但我无意绘制一堆 map ,这可能是在
Cloudflare 代理包含一个名为 CF-Connecting-IP 的 header 和用户的真实 IP。我想让 traefik 读取这个 header 并用它的内容创建一个 X-Real-Ip
我想要上下文菜单中的不同菜单项,具体取决于我在 JTable 中单击的行 大多数示例并没有真正显示上下文菜单(应该根据上下文 - 所选行进行填充) 我尝试过这个: popupMenu = ne
我有一个对象 callInst。如何获取函数的真实名称而不是 IR 代码中的名称?如果我在我的通行证中运行此代码(Useless 在另一个问题中发布) StringRef get_function_n
我在 Appium 和 iPad 2 上使用了以下所需的功能 DesiredCapabilities capabilities = new DesiredCapabilities(); capabil
根据documentation 我们可以通过以下方式在模拟器上运行我们的 android 项目: cordova 运行 android 或 cordova emulate android 但是如何在真
在 ASP.NET 中,有没有办法获得真正的原始 URL? 例如,如果用户浏览到“http://example.com/mypage.aspx/%2F”,我希望能够获得“http://example.
我的 NSInputStream 遇到问题。这是我的代码: case NSStreamEventHasBytesAvailable: printf("BYTE AVAILABLE\n"
$(selector).click() 结果没有任何反应。 this answer在浏览器控制台中工作,javascript 上下文设置为 iframe,但不是主页: simulateMouseCli
我在我的 AB Micro820 PLC 中设置了 modbus 映射。我在 40001 中有一个数组用于写入,在 42001 中有一个数组用于读取。两者都是 200 个元素和 REAL 类型(32
我正在寻找有关设计契约(Contract)管理数据模型的建议。因此,合约的一般生命周期是: 契约(Contract)已创建并处于“草稿”状态。它可以在内部查看,并且可以进行更改。 契约(Contrac
我正在尝试让我的 WebView fullscreen 达到标准,我知道如何将它拉伸(stretch)到“全屏”,但我想做的是当您长按 WebView 并选择全屏选项时,创建全屏。有谁知道该怎么做?
我是一名优秀的程序员,十分优秀!