【发布时间】:2014-08-28 12:32:11
【问题描述】:
这是来自 junit 测试报告的故障跟踪:
java.lang.NoClassDefFoundError: org/hamcrest/SelfDescribing
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:800)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
at java.lang.reflect.Constructor.newInstance(Constructor.java:526)
Caused by: java.lang.ClassNotFoundException: org.hamcrest.SelfDescribing
at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
这是我的 build.xml:
<project name="Ant-Test-JUnit" default="main">
<description>
JUnit Test on MyMath
</description>
<property name="src.dir" location="src"/>
<property name="bin.dir" location="bin"/>
<!-- Variables used for JUnit testin -->
<property name="test.dir" location="src" />
<property name="test.report.dir" location="testreport" />
<path id="test.classpath">
<pathelement location="${bin.dir}" />
<pathelement location="../../../../plugins/org.junit_4.11.0.v201203080030/junit.jar" />
<pathelement location="../../../../plugins/org.hamcrest.core_1.3.0.v201303031735.jar"/>
</path>
<!-- =================================
target: main
================================= -->
<target name="main" depends="compile, junit">
<echo message="Junit Test :)"/>
</target>
<!-- - - - - - - - - - - - - - - - - -
target: compile
- - - - - - - - - - - - - - - - - -->
<target name="compile" depends="clean, makedir">
<javac includeantruntime="false" srcdir="${src.dir}" destdir="${bin.dir}">
<classpath refid="test.classpath"/>
</javac>
</target>
<!-- - - - - - - - - - - - - - - - - -
target: clean, makedir
- - - - - - - - - - - - - - - - - -->
<target name="clean">
<delete dir="${bin}"/>
<delete dir="${test.report.dir}" />
</target>
<target name="makedir">
<mkdir dir="${bin.dir}"/>
<mkdir dir="${test.report.dir}" />
</target>
<!-- - - - - - - - - - - - - - - - - -
target: junit
- - - - - - - - - - - - - - - - - -->
<target name="junit" depends="compile">
<junit printsummary="yes" fork="true" haltonfailure="yes">
<classpath refid="test.classpath" />
<formatter type="xml" />
<batchtest todir="${test.report.dir}">
<fileset dir="${src.dir}">
<include name="**/*UnitTest*.java" />
</fileset>
</batchtest>
</junit>
</target>
我已将 Junit_4.11 jar 添加到 Preference->Ant->Runtime->Global Entries 并将 org.hamcrest.* 打包到 Preference->JUnit->Add Packages(但这并不能解决 NoClassDefFoundError:org/hamcrest/SelfDescribing 的问题)
如果我直接在 Eclipse 中使用 JUnit 插件运行 UnitTest*.java,它会工作并显示所有通过的测试。
谁能帮我找出解决办法?谢谢。
【问题讨论】:
标签: java eclipse ant junit build