问题描述
我有一个简单的带有AWS SQS集成的spring boot应用程序。 在集成测试中,我尝试监视使用@SqsListener批注进行批注的方法,并得到一种行为,其中没有窥探bean 有时。
您可以在此处查看示例项目:https://github.com/Sanych/aws-sqs-spybean-troubleshooting
运行mvn clean verify
在此日志中,可能会注意到,成功侦破了3种测试方法中的2种:
2020-09-06 15:39:23.597 INFO 18372 --- [ main] com.aws.test.demo.SQSListenerIT : Started SQSListenerIT in 0.813 seconds (JVM running for 24.024)
2020-09-06 15:39:23.604 WARN 18372 --- [ main] com.aws.test.demo.SQSListenerIT : calling class com.aws.test.demo.SQSListener$MockitoMock$1506819983
2020-09-06 15:39:23.604 WARN 18372 --- [ main] com.aws.test.demo.SQSListenerIT : sendMessage to queue: test 1
2020-09-06 15:39:23.810 WARN 18372 --- [enerContainer-2] com.aws.test.demo.SQSListener : id: class com.aws.test.demo.SQSListener$MockitoMock$1506819983,received: 'test 1'
2020-09-06 15:39:23.929 WARN 18372 --- [ main] com.aws.test.demo.SQSListenerIT : calling class com.aws.test.demo.SQSListener$MockitoMock$1506819983
2020-09-06 15:39:23.929 WARN 18372 --- [ main] com.aws.test.demo.SQSListenerIT : sendMessage to queue: test 2
2020-09-06 15:39:24.052 WARN 18372 --- [enerContainer-2] com.aws.test.demo.SQSListener : id: class com.aws.test.demo.SQSListener,received: 'test 2'
2020-09-06 15:39:29.148 WARN 18372 --- [ main] com.aws.test.demo.SQSListenerIT : calling class com.aws.test.demo.SQSListener$MockitoMock$1506819983
2020-09-06 15:39:29.148 WARN 18372 --- [ main] com.aws.test.demo.SQSListenerIT : sendMessage to queue: test 3
2020-09-06 15:39:29.175 WARN 18372 --- [enerContainer-2] com.aws.test.demo.SQSListener : id: class com.aws.test.demo.SQSListener$MockitoMock$1506819983,received: 'test 3'
[ERROR] Tests run: 3,Failures: 0,Errors: 1,Skipped: 0,Time elapsed: 6.468 s <<< FAILURE! - in com.aws.test.demo.SQSListenerIT
[ERROR] test2 Time elapsed: 5.218 s <<< ERROR!
org.awaitility.core.ConditionTimeoutException:
Assertion condition defined as a lambda expression in com.aws.test.demo.SQSListenerIT
Wanted but not invoked:
SQSListener.listen(<any string>);
-> at com.aws.test.demo.SQSListenerIT.lambda$sendMessageFromFileAndWaitForListenerToRead$0(SQSListenerIT.java:57)
Actually,there were zero interactions with this mock.
within 5 seconds.
at com.aws.test.demo.SQSListenerIT.sendMessageFromFileAndWaitForListenerToRead(SQSListenerIT.java:57)
at com.aws.test.demo.SQSListenerIT.test2(SQSListenerIT.java:42)
Caused by: org.mockito.exceptions.verification.WantedButnotinvoked:
Wanted but not invoked:
SQSListener.listen(<any string>);
-> at com.aws.test.demo.SQSListenerIT.lambda$sendMessageFromFileAndWaitForListenerToRead$0(SQSListenerIT.java:57)
Actually,there were zero interactions with this mock.
at com.aws.test.demo.SQSListenerIT.lambda$sendMessageFromFileAndWaitForListenerToRead$0(SQSListenerIT.java:57)
我想念什么吗?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)