笔者按:
这个是一篇老文了,之前解决出来发到邮件群里了,换了笔记本发现邮件没有了。今天不经意间又发现了,防止再次失踪,于是记录到博客里,以作备案。
关于什么是jtester,可以看下这个论坛贴子。
[url]http://www.iteye.com/topic/900975[/url]
正文:
笔者今日发现,自己新装Eclipse3.5,下载的JTester工程,装了TestNG插件,写一个JTester的单元测试。
但运行都报错了。其他同事运行的单元测试却没有问题,觉得奇怪。刚开始怀疑是JDK问题,
我下载了JDK1.6.0.17,JDK1.6.0.20,JDK1.6.0.22都不行。还是报同样的错误:
[b]现象:[/b]
[b]分析:[/b]
我通过DEBUG代码,发现在jtester包中的Startup类中执行loadInternalStartupMocks方法里报错具体在这一行:
JTester在启动时设置各个测试框架的Mock时,唯独TestNG的报错了。于是我开始验证,
1.建立继承以Junit4的JTester的测试类,可以正常运行;
2.单独建立基类是TestNG也可以运行
3.建立扩展以TestNG为基础的JTester无法运行。
所以,我得出结论,当前TestNG插件版本与JTester是不兼容的。
我检查了自己运行的TestNG插件版本,在Eclipse这里查看:(图中的TestNG笔者已经卸载掉)
[img]http://dl.iteye.com/upload/attachment/426109/75b6dd2f-3396-3b9d-a7b4-3cb0deb70d8a.png[/img]
[b]验证:[/b]
发现TestNG版本是5.14.2.9。该版本是通过eclipse中的install new software 中[url]http://beust.com/eclipse[/url]这个地址下载。
而其他同事(运行正常)的版本是:5.14.0.1,或者5.13.x。
于是我先点击Uninstall将TestNG版本删除,退出eclipse,到eclipse的安装目录,将plugins中的org.testng.eclipse_5.14.2.9的目录删除(这样才能彻底删除)。
再从[url]http://testng.org/testng-eclipse-5.14.0.1.zip[/url]这里下载。将其解压,拷贝到plugins目录下。你 也可以使用附件中jar文件,将他拷贝到eclipse安装目录下的plugins中。安装重启Eclipse,之后再运行单元测试,JTester又出现了绿色!
[b]总结:[/b]
如果你要开始使用JTester,请不要使用[url]http://beust.com/eclipse[/url]的Update方式下载TestNG插件,直接使用org.testng.eclipse_5.14.0.1.jar文件。
这个是一篇老文了,之前解决出来发到邮件群里了,换了笔记本发现邮件没有了。今天不经意间又发现了,防止再次失踪,于是记录到博客里,以作备案。
关于什么是jtester,可以看下这个论坛贴子。
[url]http://www.iteye.com/topic/900975[/url]
正文:
笔者今日发现,自己新装Eclipse3.5,下载的JTester工程,装了TestNG插件,写一个JTester的单元测试。
但运行都报错了。其他同事运行的单元测试却没有问题,觉得奇怪。刚开始怀疑是JDK问题,
我下载了JDK1.6.0.17,JDK1.6.0.20,JDK1.6.0.22都不行。还是报同样的错误:
[b]现象:[/b]
Setting connection parameters:127.0.0.1:39337
init jmockit:true
Exception in thread "Attach Listener" java.lang.reflect.InvocationTargetException
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at sun.instrument.InstrumentationImpl.loadClassAndStartAgent(InstrumentationImpl.java:323)
at sun.instrument.InstrumentationImpl.loadClassAndCallAgentmain(InstrumentationImpl.java:348)
Caused by: java.lang.IllegalArgumentException: Matching real methods not found for the following mocks:
Object invokeMethod(reflect.Method, Object, Object[])
at mockit.internal.RedefinitionEngine.modifyRealClass(RedefinitionEngine.java:259)
at mockit.internal.RedefinitionEngine.modifyRealClass(RedefinitionEngine.java:235)
at mockit.internal.RedefinitionEngine.redefineMethods(RedefinitionEngine.java:209)
at mockit.internal.RedefinitionEngine.setUpStartupMock(RedefinitionEngine.java:185)
at mockit.internal.startup.Startup.setUpInternalStartupMock(Startup.java:181)
at mockit.internal.startup.Startup.loadInternalStartupMocks(Startup.java:161)
at mockit.internal.startup.Startup.initialize(Startup.java:139)
at mockit.internal.startup.Startup.agentmain(Startup.java:128)
... 6 more
[b]分析:[/b]
我通过DEBUG代码,发现在jtester包中的Startup类中执行loadInternalStartupMocks方法里报错具体在这一行:
private static void loadInternalStartupMocks()
{
setUpInternalStartupMock(TestSuiteDecorator.class);
setUpInternalStartupMock(JUnitTestCaseDecorator.class);
setUpInternalStartupMock(RunNotifierDecorator.class);
setUpInternalStartupMock(BlockJUnit4ClassRunnerDecorator.class);
setUpInternalStartupMock(TestNGTestRunnerDecorator.class); //这里抛出了异常
TestRun.mockFixture().turnRedefinedClassesIntoFixedOnes();
}
JTester在启动时设置各个测试框架的Mock时,唯独TestNG的报错了。于是我开始验证,
1.建立继承以Junit4的JTester的测试类,可以正常运行;
2.单独建立基类是TestNG也可以运行
3.建立扩展以TestNG为基础的JTester无法运行。
所以,我得出结论,当前TestNG插件版本与JTester是不兼容的。
我检查了自己运行的TestNG插件版本,在Eclipse这里查看:(图中的TestNG笔者已经卸载掉)
[img]http://dl.iteye.com/upload/attachment/426109/75b6dd2f-3396-3b9d-a7b4-3cb0deb70d8a.png[/img]
[b]验证:[/b]
发现TestNG版本是5.14.2.9。该版本是通过eclipse中的install new software 中[url]http://beust.com/eclipse[/url]这个地址下载。
而其他同事(运行正常)的版本是:5.14.0.1,或者5.13.x。
于是我先点击Uninstall将TestNG版本删除,退出eclipse,到eclipse的安装目录,将plugins中的org.testng.eclipse_5.14.2.9的目录删除(这样才能彻底删除)。
再从[url]http://testng.org/testng-eclipse-5.14.0.1.zip[/url]这里下载。将其解压,拷贝到plugins目录下。你 也可以使用附件中jar文件,将他拷贝到eclipse安装目录下的plugins中。安装重启Eclipse,之后再运行单元测试,JTester又出现了绿色!
[b]总结:[/b]
如果你要开始使用JTester,请不要使用[url]http://beust.com/eclipse[/url]的Update方式下载TestNG插件,直接使用org.testng.eclipse_5.14.0.1.jar文件。