java.lang.IllegalStateException: 2 matchers expected, 1 recorded. 问题解决的正确姿势

一、背景

今天使用Mokito遇到一个类似的问题,找到了一篇关于EasyMock的类似的异常博客,参考这个思考解决了问题。

 

二、原文

EasyMock是一个不错的mock接口的框架。

大多数情况下都用着很爽,但是如果使用复杂的用法可能会出问题。

如果你把所有参数都传给需要mock的函数,没有问题。

但是有时候无法预测Mock所需的所有参数,看下面的例子:

MyData myData = EasyMock.createNiceMock( MyData.class );
MyService serviceMock = EasyMock.createMock( MyService.class );

看起来啥问题。

这段代码告诉 serviceMock调用doSth函数。第二个参数应该是一个myData对象,和第一个参数没关系。

但是不幸的是,我们得到了如下异常:

java.lang.IllegalStateException: 2 matchers expected, 1 recorded.
	at org.easymock.internal.ExpectedInvocation.createMissingMatchers(ExpectedInvocation.java:56)
	at org.easymock.internal.ExpectedInvocation.(ExpectedInvocation.java:48)
	at org.easymock.internal.ExpectedInvocation.(ExpectedInvocation.java:40)
	at org.easymock.internal.RecordState.invoke(RecordState.java:76)
	at org.easymock.internal.MockInvocationHandler.invoke(MockInvocationHandler.java:38)
	at org.easymock.internal.ObjectMethodsFilter.invoke(ObjectMethodsFilter.java:72)
	at org.easymock.classextension.internal.ClassProxyFactory$MockMethodInterceptor.intercept(ClassProxyFactory.java:93

原因是我们Mock的时候,将value(如参数是Long 传 5L)和matchers(如anyObject()函数就是一个matcher)混用

类似这种

Mockito.when(mokitoDemo.getXXX(2, 3, anyBoolean())).thenReturn(result);

要解决这个问题,可以将所有参数都用matcher来代替值。

  Mockito.when(mokitoDemo.getXXX(eq(2), eq(3),  anyBoolean())).thenReturn(result);

EasyMock的手册给出了所有matcher的使用说明:

http://easymock.org/user-guide.html#verification-expectations

原文:https://weirdfellow.wordpress.com/2010/07/15/2-matchers-expected-1-recorded/

三、推荐Mock测试

借着本文的机会,再次极力!提倡mock测试。

可以在底层接口未开发完成即可测试自己的逻辑是否通。

比如环境不允许,包括本地无数据库,包括调用的外部接口没上线等。

 

可以在单元测试阶段发现很多粗心的错误,一些代码逻辑的错误等,极大提高编程质量。

 

mokito参考资料:

https://www.vogella.com/tutorials/Mockito/article.html

https://www.pdfdrive.com/mockito-for-spring-d31187480.html

 

如果觉得本文对你有帮助,欢迎点赞,欢迎关注我,如果有补充欢迎评论交流,我将努力创作更多更好的文章。

Caused by: java.lang.IllegalStateException: Logback configuration error detected问题是由于Logback配置错误引起的。根据引用和引用的信息,可能的解决办法如下: 1. 检查Logback的配置文件,确保配置文件的语法和结构正确。可以尝试重新编写或更新Logback配置文件。 2. 检查Logback依赖是否正确添加到项目的依赖管理中。可以使用Maven或Gradle等构建工具来管理项目的依赖。 3. 检查Logback的日志输出路径和文件权限,确保日志文件可以被正常写入。 4. 检查Logback的日志输出级别,确保日志级别的设置与期望的输出一致。 5. 检查Logback的相关组件和库是否与项目的其他组件和库版本兼容,避免引起冲突或不兼容问题。 6. 如果以上方法都无法解决问题,可以尝试搜索相关错误信息和解决方案,参考引用提供的Android Caused by: java.lang.ClassNotFoundException解决办法的相关资料,看是否能找到类似的解决方法来解决Logback配置错误的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [关于Caused by: java.lang.IllegalStateException:问题解决办法!](https://blog.csdn.net/m0_52255061/article/details/115248503)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [Android Caused by: java.lang.ClassNotFoundException解决办法](https://download.csdn.net/download/weixin_38703295/12784351)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

明明如月学长

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值