现象及日志
最近使用Robolectric 4.2针对Android 27进行测试,出现JVM Crash发现错误,log如下:
原因分析
当在日志中显示“ Current thread: JavaThread " CompilerThread"时 可能是触发了JVM的编译器的BUG导致的。可以看出是android.content.res.TypedArray导致的JVM Native Crash.
解决方法
在gradle中加入如下方法可以解决:
tests.withType(Test) {
jvmArgs "-XX:CompileCommand=exclude, android/content/res/TypedArrays*.*"
}
该jvm参数意味着android.content.res.TypedArrays中的任何代码都不会经过JIT编译,而是一直解释执行,从而绕过JIT的bug。
参考
【1】https://github.com/robolectric/robolectric/issues/3202.