`

解决junit4.4和jmockit的冲突

    博客分类:
  • java
阅读更多
    今天开发中遇到的问题,代码提交到svn上去之后,hundson很快就红了。

    检查hundson,发现该项目下所有的junit测试案例都失败了,所以的case都是一个错误:

java.lang.reflect.InvocationTargetException
	at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
Caused by: java.lang.NoClassDefFoundError: org/junit/runner/Describable
	at java.lang.ClassLoader.defineClass1(Native Method)
	at java.lang.ClassLoader.defineClassCond(ClassLoader.java:632)
	at java.lang.ClassLoader.defineClass(ClassLoader.java:616)
	at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
	at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
	at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
	at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
	at java.lang.ClassLoader.defineClass1(Native Method)
	at java.lang.ClassLoader.defineClassCond(ClassLoader.java:632)
	at java.lang.ClassLoader.defineClass(ClassLoader.java:616)
	at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
	at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
	at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
	at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
	at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
	at java.security.AccessController.doPrivileged(Native Method)
	at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:248)


    在本地eclipse环境下没有类似问题(有点废话,肯定是本地跑过了才提交代码的),错误信息上看是junit初始化出问题,和具体case就没有关系了。

    考虑这次提交的时候修改了几个依赖,猜想是和他们有关:升级easymock 2.5.3到3.0,增加jmockit 0.997 / jsch-0.1.43。

    祭google大法,很快发现有人遇到类似问题,原因是junit 4.4版本不支持jmockit集成,需要junit 4.5或更高版本。

    随即升级junit版本,效果立竿见影,问题消失。

    记录下来,遇到类似问题的朋友,可以参考。
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics