作为标题!我不能运行任何使用MockK的测试,因为它们最终会在初始化期间抛出一个StackOverflowError。
举个例子,下面是我的一个测试类:
@ExtendWith(MockKExtension::class)
class DBSequencesServicesTest {
private lateinit var service: DBSequencesService
@MockK
private lateinit var sequencesRepo: DBSequencesRepo
@BeforeTest
fun initService() {
service = DBSequencesServiceImpl(sequencesRepo)
}
@Test
fun `should return value 0 if given a non-existent sequence`() {
every { sequencesRepo.findById(any()) } returns Optional.empty()
assertEquals(0, service.nextValue("test"))
}
@Test
fun `should return next value if given an existing sequence`() {
every { sequencesRepo.findById("test") } returns Optional.of(DBSequence("test", 1))
every { sequencesRepo.save(any()) } returnsArgument 0
assertEquals(1, service.nextValue("test"))
}
@Test
fun `successive calls should return incrementing values`() {
every { sequencesRepo.findById("test") } returnsMany listOf(
Optional.of(DBSequence("test", 0)),
Optional.of(DBSequence("test", 1)),
Optional.of(DBSequence("test", 2))
)
every { sequencesRepo.save(any()) } returnsArgument 0
for (i in 0L..2L) {
assertEquals(i, service.nextValue("test"))
}
}
}
这是结果的堆栈跟踪,一旦模式变得明显,就会被切断:
Exception in thread "Test worker" java/lang/StackOverflowError
at io/mockk/proxy/jvm/dispatcher/JvmMockKDispatcher.get (JvmMockKDispatcher.java:16)
at java/lang/Object.hashCode (Object.java:119)
at java/util/HashMap.hash (HashMap.java:339)
at java/util/HashMap.get (HashMap.java:557)
at sun/reflect/Reflection.filterMethods (Reflection.java:291)
at java/lang/Class.getMethodHelper (Class.java:1265)
at java/lang/Class.getMethod (Class.java:1191)
at java/lang/Object.hashCode (Object.java:119)
at java/util/HashMap.hash (HashMap.java:339)
at java/util/HashMap.get (HashMap.java:557)
at sun/reflect/Reflection.filterMethods (Reflection.java:291)
at java/lang/Class.getMethodHelper (Class.java:1265)
at java/lang/Class.getMethod (Class.java:1191)
at java/lang/Object.hashCode (Object.java:119)
at java/util/HashMap.hash (HashMap.java:339)
at java/util/HashMap.get (HashMap.java:557)
at sun/reflect/Reflection.filterMethods (Reflection.java:291)
at java/lang/Class.getMethodHelper (Class.java:1265)
at java/lang/Class.getMethod (Class.java:1191)
at java/lang/Object.hashCode (Object.java:119)
at java/util/HashMap.hash (HashMap.java:339)
at java/util/HashMap.get (HashMap.java:557)
...
然后抛出一个MessageIOException:
org.gradle.internal.remote.internal.MessageIOException: Could not read message from '/127.0.0.1:52775'.
at org.gradle.internal.remote.internal.inet.SocketConnection.receive(SocketConnection.java:94)
at org.gradle.internal.remote.internal.hub.MessageHub$ConnectionReceive.run(MessageHub.java:270)
at org.gradle.internal.concurrent.ExecutorPolicy$CatchAndRecordFailures.onExecute(ExecutorPolicy.java:64)
at org.gradle.internal.concurrent.ManagedExecutorImpl$1.run(ManagedExecutorImpl.java:48)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at org.gradle.internal.concurrent.ThreadFactoryImpl$ManagedThreadRunnable.run(ThreadFactoryImpl.java:56)
at java.lang.Thread.run(Thread.java:821)
据我所知,我正确地设置了MockK,并根据他们的指南使用它:
dependencies {
// Other dependencies go here...
testImplementation("org.springframework.boot:spring-boot-starter-test") {
exclude(group = "org.junit.vintage", module = "junit-vintage-engine")
}
testImplementation("org.springframework.security:spring-security-test")
testImplementation("org.jetbrains.kotlin:kotlin-test-junit5:1.4.10")
testImplementation("io.mockk:mockk:1.10.2")
testImplementation("com.ninja-squad:springmockk:2.0.3")
}
是什么导致了这个异常,我该如何解决呢?如果需要更多的上下文,请告诉我。
编辑:当CircleCI使用映像cimg/openjdk:8.0
运行测试时,不会发生相同的异常
编辑2:添加了DBSequence
和DBSequenceRepo
的定义
@Document(collection = "dbSequences")
data class DBSequence(
@Id var name: String,
var nextVal: Long
) {
override fun equals(other: Any?): Boolean {
if (this === other) return true
if (javaClass != other?.javaClass) return false
other as DBSequence
if (name != other.name) return false
return true
}
override fun hashCode(): Int {
return name.hashCode()
}
}
interface DBSequencesRepo : MongoRepository<DBSequence, String>
发布于 2020-11-03 16:21:24
今天,我们在本地机器上遇到了类似的问题。我们正在尝试使用vert.x和Kotlin来实现后端服务的MockK。
我们的开发机器是带有OpenJDK 11.0.9的MacOs,由于某些奇怪的原因,有时运行时没有问题,有时会保持活动状态,直到抛出测试超时并附带以下消息:
per (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/reflect/Reflection.filterMethods (java.base@9/Reflection.java:276)
at java/lang/Class.getMethodHelper (java.base@9/Class.java:1457)
at java/lang/Class.getMethod (java.base@9/Class.java:1361)
at java/lang/Object.hashCode (java.base@9/Object.java:122)
at java/util/HashMap.hash (java.base@9/HashMap.java:339)
at java/util/HashMap.get (java.base@9/HashMap.java:552)
at jdk/internal/
当我们在Idea项目中将JDK设置为8.*时,会出现这样的情况:一个测试通过,而一个测试失败,错误与上面所示的相同。
我不是MockK库的专家,但我非常有兴趣将它与莫奇托-科特林进行比较。当与JDK的最新版本一起使用时,IMO库在反射方面存在一些问题。
https://stackoverflow.com/questions/64556991
复制相似问题