jMockit初始化时出错:java.lang.IllegalStateException:在JDK 9上运行

use*_*641 3 java eclipse junit jmockit java-9

jmockit无法在eclipse中初始化:java.lang.IllegalStateException:在JDK 9上运行需要-javaagent:/jmockit-1.n.jar或-Djdk.attach.allowAttachSelf

如果我添加-Djdk.attach.allowAttachSelfVM参数,它可以正常工作.

为什么我需要添加该参数?jmockit并不是说在JDK 9上运行时是必需的.是的,JRE系统库指向JDK,是的,jmockit jar按照外部库的顺序高于junit.

版本:JUnit 4.12,Java jdk 9.0.1,jmockit 1.37,hamcrest core 1.3

java.base上的java.lang.ExceptionInInitializerError(testClass.java:20)java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl) .java:62)在org的java.base/java.lang.reflect.Method.invoke(Method.java:564)的java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43).在org.junit.runners.model.FrameworkMethod.invokeExplosively的org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)中的junit.runners.model.FrameworkMethod $ 1.runReflectiveCall(FrameworkMethod.java:50) (FrameworkMethod.java:47)org.junit上的org.junit.runners.Statements.InvokeMethod.evaluate(InvokeMethod.java:17)org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325). runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRu)nner.java:57)org.junit.runners.ParentRunner $ 3.run(ParentRunner.java:290)org.junit.runners.ParentRunner $ 1.schedule(ParentRunner.java:71)org.junit.runners.ParentRunner .runChildren(ParentRunner.java:288)位于org.junit的org.junit.runners.rarentRunner.access $ 000(ParentRunner.java:58)org.junit.runners.ParentRunner $ 2.evaluate(ParentRunner.java:268). runners.ParentRunner.run(ParentRunner.java:363)位于org.eclipse.jdt.internal.junit.runner.TestExecution的org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86).运行(TestExecution.java:38)org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:539)org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner. java:761)org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:461)org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:207)引起:java.lang.IllegalStateException:运行 在JDK 9上需要在mockit.internal.startup.AgentLoader.loadAgent的mockit.internal.startup.AgentLoader.attachToRunningVM(AgentLoader.java:155)中使用-javaagent:/jmockit-1.n.jar或-Djdk.attach.allowAttachSelf (AgentLoader.java:60)at mockit.internal.startup.Startup.verifyInitialization(Startup.java:137)at mockit.Invocations.(Invocations.java:26)... 24更多

Nam*_*man 5

-Djdk.attach.allowAttachSelf vm参数,它工作正常.

为什么我需要添加该参数?

JDK9中的参数用于附加到本地VM本身,换言之,用于自我附加.

jmockit大多数情况下使用仪器自我附加,这是他们需要这样一个标志的地方.此外,必须在JDK8或之前忽略此必须参数.

可以在拼图邮件列表上找到对此相关的初步讨论.


类似的讨论和解决方法是在提出字节好友#295@Rafael: -

ByteBuddyAgent.install() 现在可以检测禁止自我附件的Java 9 VM,并创建一个从那里附加的帮助程序.

  • 我想说*真正的原因是因为一些Oracle JDK工程师做出了这种任意的,无效的,最终是非感性的决定,即添加命令行标志作为防止恶意代码从字节码中检测正在运行的JVM的方法.通过创建一个新进程然后附加回原始进程,库可以轻松地在标志周围工作的事实证明该标志没有实现任何有用的功能.相反,他们应该只依赖已经存在的`AttachPermission`. (5认同)