【问题标题】:JVMJ9VM007E Command-line option unrecognised: -javaagentJVMJ9VM007E 无法识别命令行选项:-javaagent
【发布时间】:2016-07-26 13:18:54
【问题描述】:

当我尝试使用 IBM JDK 运行简单的 jMockit/JUnit 测试时遇到以下异常。

java.lang.ExceptionInInitializerError 
    at java.lang.J9VMInternals.initialize(J9VMInternals.java:222)
    at java.lang.J9VMInternals.initialize(J9VMInternals.java:167)
    at java.lang.J9VMInternals.initialize(J9VMInternals.java:167)
    at java.lang.J9VMInternals.initialize(J9VMInternals.java:167)
    at com.chubb.prssearchpolicy.test.PRSSearchPolicyResourceTest.init(PRSSearchPolicyResourceTest.java:47)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
    at java.lang.reflect.Method.invoke(Method.java:611)
    at org.junit.internal.runners.BeforeAndAfterRunner.invokeMethod(BeforeAndAfterRunner.java:74)
    at org.junit.internal.runners.BeforeAndAfterRunner.runBefores(BeforeAndAfterRunner.java:50)
    at org.junit.internal.runners.BeforeAndAfterRunner.runProtected(BeforeAndAfterRunner.java:33)
    at org.junit.internal.runners.TestMethodRunner.runMethod(TestMethodRunner.java:75)
    at org.junit.internal.runners.TestMethodRunner.run(TestMethodRunner.java:45)
    at org.junit.internal.runners.TestClassMethodsRunner.invokeTestMethod(TestClassMethodsRunner.java:66)
    at org.junit.internal.runners.TestClassMethodsRunner.run(TestClassMethodsRunner.java:35)
    at org.junit.internal.runners.TestClassRunner$1.runUnprotected(TestClassRunner.java:42)
    at org.junit.internal.runners.BeforeAndAfterRunner.runProtected(BeforeAndAfterRunner.java:34)
    at org.junit.internal.runners.TestClassRunner.run(TestClassRunner.java:52)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:49)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: java.lang.RuntimeException: com.sun.tools.attach.AttachNotSupportedException: Unable to enqueue operation: the target VM does not support attach mechanism
    at mockit.internal.startup.AgentLoader.attachToRunningVM(AgentLoader.java:136)
    at mockit.internal.startup.AgentLoader.loadAgent(AgentLoader.java:53)
    at mockit.internal.startup.Startup.verifyInitialization(Startup.java:172)
    at mockit.Invocations.<clinit>(Invocations.java:26)
    at java.lang.J9VMInternals.initializeImpl(Native Method)
    at java.lang.J9VMInternals.initialize(J9VMInternals.java:200)
    ... 24 more
Caused by: com.sun.tools.attach.AttachNotSupportedException: Unable to enqueue operation: the target VM does not support attach mechanism
    at sun.tools.attach.WindowsVirtualMachine.<init>(WindowsVirtualMachine.java:64)
    at sun.tools.attach.WindowsAttachProvider.attachVirtualMachine(WindowsAttachProvider.java:64)
    at com.sun.tools.attach.VirtualMachine.attach(VirtualMachine.java:213)
    at mockit.internal.startup.AgentLoader.attachToRunningVM(AgentLoader.java:133)
    ... 29 more

为此,我在运行配置中传递了 VM 参数,但出现以下错误:

JVMJ9VM007E 无法识别命令行选项:-javaagent=C:\Users\junit\jmockit.jar

有人遇到过这个问题吗?我们将不胜感激。

【问题讨论】:

    标签: java junit path jvm jmockit


    【解决方案1】:

    您可以尝试添加以下参数 -Dcom.ibm.tools.attach.enable=yes 并且 jdk tools.jar 文件应该在您的类路径中

    另外,请查看这篇与您的惊人相似的帖子。根据接受的答案,其中一个发行版中存在一个错误,需要在类路径中使用 TestNG 作为解决方法。 AttachNotSupportedException while running jMockit tests on IBM JRE

    【讨论】: