2011-12-30 59 views
1

在Eclipse和IntelliJ中运行UISpec测试用例时,我收到了上述错误消息(java.lang.UnsatisfiedLinkError)。运行uispec4j测试用例时的java.lang.UnsatisfiedLinkError

我安装了sun/oracle JDK 1.7。

错误的报告全文

> Exception in thread "main" java.lang.UnsatisfiedLinkError: 
> sun.awt.motif.MToolkit.init(Ljava/lang/String;)V at 
> sun.awt.motif.MToolkit.init(Native Method) at 
> sun.awt.motif.MToolkit.<init>(MToolkit.java:146) at 
> sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
>  at 
> sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57) 
>  at 
> sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
>  at java.lang.reflect.Constructor.newInstance(Constructor.java:525) 
>  at java.lang.Class.newInstance0(Class.java:372)  at 
> java.lang.Class.newInstance(Class.java:325)  at 
> org.uispec4j.interception.toolkit.UISpecToolkit.buildUnderlyingToolkit(UISpecToolkit.java:128) 
>  at 
> org.uispec4j.interception.toolkit.UISpecToolkit.setUp(UISpecToolkit.java:39) 
>  at 
> org.uispec4j.interception.toolkit.UISpecToolkit.<init>(UISpecToolkit.java:24) 
>  at org.uispec4j.UISpec4J.initToolkit(UISpec4J.java:39) at 
> org.uispec4j.UISpec4J.init(UISpec4J.java:31) at 
> org.uispec4j.UISpecTestCase.<clinit>(UISpecTestCase.java:31) at 
> sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
>  at 
> sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57) 
>  at 
> sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
>  at java.lang.reflect.Constructor.newInstance(Constructor.java:525) 
>  at junit.framework.TestSuite.createTest(TestSuite.java:131)  at 
> junit.framework.TestSuite.addTestMethod(TestSuite.java:114)  at 
> junit.framework.TestSuite.<init>(TestSuite.java:75)  at 
> com.intellij.junit3.TestRunnerUtil.createClassOrMethodSuite(TestRunnerUtil.java:140) 
>  at 
> com.intellij.junit3.TestRunnerUtil.getTestSuite(TestRunnerUtil.java:79) 
>  at 
> com.intellij.junit3.JUnit3IdeaTestRunner.startRunnerWithArgs(JUnit3IdeaTestRunner.java:50) 
>  at 
> com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:202) 
>  at 
> com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:63) 
>  at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at 
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
>  at 
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
>  at java.lang.reflect.Method.invoke(Method.java:601)  at 
> com.intellij.rt.execution.application.AppMain.main(AppMain.java:120) 
> 
> Process finished with exit code 1 

如果有人经历过同样的问题,请帮助我。

回答

2

看起来像一个已知的Java Bug:6996291

这个问题似乎是由引起的,UISpec在Linux上明确加载sun.awt.motif.MToolkit,而此工具包在JDK 1.7中不再可用。查看是否有方法在UISpec配置中将其禁用,或将问题报告给开发人员。

作为解决方法,您可以使用Oracle JDK 1.6.0。

+0

谢谢老兄。我会看看。 – Athiruban 2011-12-30 11:19:05

+0

你确实是对的。问题是由于JDK 1.7中的工具包不可用。但是当我运行> javap sun.awt.Motif.MToolkit时,它显示了类声明。所以我认为这个类在JDK1.7中可用。另外,我向UISpec开发团队报告了这个问题。再一次,非常感谢。 – Athiruban 2011-12-30 12:43:01

1

我有完全相同的问题,但使用openjdk(在Linux Mint下)。改用openjdk并安装sun-java6-jdk(使用Linux-Software-Manager)解决了这个问题。