GWTTestCase:回调中的JUnit断言引发了JavaScriptException

时间:2012-03-11 07:12:07

标签: java gwt junit gwttestcase

因此,如果我调用任何在回调方法中失败的JUnit断言,我会得到以下异常:

Mar 12, 2012 11:24:41 AM 

com.gargoylesoftware.htmlunit.javascript.background.JavaScriptJobManagerImpl runJob
SEVERE: Job run failed with unexpected RuntimeException: [object Class JavaObject] (injected script#14)
net.sourceforge.htmlunit.corejs.javascript.JavaScriptException: [object Class JavaObject] (injected script#14)
    at net.sourceforge.htmlunit.corejs.javascript.Interpreter.interpretLoop(Interpreter.java:1062)
    at script(injected script:14)
    at net.sourceforge.htmlunit.corejs.javascript.Interpreter.interpret(Interpreter.java:845)
    at net.sourceforge.htmlunit.corejs.javascript.InterpretedFunction.call(InterpretedFunction.java:164)
    at net.sourceforge.htmlunit.corejs.javascript.ContextFactory.doTopCall(ContextFactory.java:429)
    at com.gargoylesoftware.htmlunit.javascript.HtmlUnitContextFactory.doTopCall(HtmlUnitContextFactory.java:269)
    at net.sourceforge.htmlunit.corejs.javascript.ScriptRuntime.doTopCall(ScriptRuntime.java:3162)
    at net.sourceforge.htmlunit.corejs.javascript.InterpretedFunction.call(InterpretedFunction.java:162)
    at com.gargoylesoftware.htmlunit.javascript.JavaScriptEngine.callFunction(JavaScriptEngine.java:559)
    at com.gargoylesoftware.htmlunit.javascript.host.xml.XMLHttpRequest.setState(XMLHttpRequest.java:181)
    at com.gargoylesoftware.htmlunit.javascript.host.xml.XMLHttpRequest.doSend(XMLHttpRequest.java:525)
    at com.gargoylesoftware.htmlunit.javascript.host.xml.XMLHttpRequest.access$000(XMLHttpRequest.java:64)
    at com.gargoylesoftware.htmlunit.javascript.host.xml.XMLHttpRequest$1.run(XMLHttpRequest.java:461)
    at net.sourceforge.htmlunit.corejs.javascript.Context.call(Context.java:537)
    at net.sourceforge.htmlunit.corejs.javascript.ContextFactory.call(ContextFactory.java:538)
    at com.gargoylesoftware.htmlunit.javascript.host.xml.XMLHttpRequest$2.run(XMLHttpRequest.java:467)
    at com.gargoylesoftware.htmlunit.javascript.background.JavaScriptJobManagerImpl.runJob(JavaScriptJobManagerImpl.java:226)
    at com.gargoylesoftware.htmlunit.javascript.background.JavaScriptJobManagerImpl.runSingleJob(JavaScriptJobManagerImpl.java:307)
    at com.gargoylesoftware.htmlunit.javascript.background.JavaScriptExecutor.run(JavaScriptExecutor.java:182)
    at java.lang.Thread.run(Thread.java:722)

产生这个的简单测试:

public void testSimple() {
    MyPrgrmServiceAsync serv = GWT.create(MyPrgrmService.class);
    serv.search("some query", new AsyncCallback<SearchResult>() {
        public void onSuccess(SearchResult sr) {
            fail();
        }

        public void onFailure(Throwable caught) {
            fail(caught.toString());
        }
    });

    delayTestFinish(60000);
}

当这个测试运行时,它会通过&#34;至于JUnit Runner关注Eclipse中显示的绿色条,但显然它应该失败。任何出错的唯一迹象是控制台中的异常。如果我在回调之外移动fail(),它会正常失败并指示如此。此外,解析为true的断言行为正常,因此测试似乎根本不知道如何在匿名类中发现失败。对于如何在回调/匿名类中使用关于GWTTestCase的JUnit断言,我是否有不正确的理解?

2 个答案:

答案 0 :(得分:1)

您的基本理解似乎是正确的 - delayTestFinish的任务是不允许测试通过,除非在给定的毫秒数内调用finishTest()(在您的情况下为60秒)。无需在任何回调方法中调用finishTest(),因为fail将抛出异常(如果代码甚至达到那么远)。

您确定测试成功完成吗?如上所述,如果某些内容配置错误并且调用永远不会进入服务器,或者服务器永远不会返回,则无法调用failfinishTest,因此测试方法无法通过。确保在接受结果为“已通过”之前等待整整60秒 - 如果从未调用finishTest,则测试方法将不会被视为完成,或者应将其视为失败。

也就是说,这个异常很有用 - 这是来自模拟浏览器 - htmlunit - 而且这个异常在'浏览器'中出错了。从短跟踪而不是其他日志语句中很难说究竟出了什么问题。您也可以考虑在真实的浏览器中运行它以查看是否显示更多有用的错误 - 请查看http://code.google.com/webtoolkit/doc/latest/DevGuideTestingRemoteTesting.html如何在开发或生产模式下从常规浏览器运行测试。

另一个想法可能是用GWT注册一个未捕获的异常处理程序来查看它的内容 - 有可能是其他一些异常正在杀死测试,并以某种方式这样做以防止delayTestFinish正常运行(虽然我从来没有听说过这样的事情)。

GWT.setUncaughtExceptionHandler(new UncaughtExceptionHandler() {
  public void onUncaughtException(Throwable e) {
    fail(e.getMessage());
  }
});

答案 1 :(得分:0)

问题是我在gwtSetUp()中调用了finishTest()。我在那里运行了一些初始化代码,这是一个异步方法,并且希望确保它在实际测试代码之前完成,但事实证明它只是在实际测试之前完成测试。故事的道德:不要对你的finishTest()放置感到愚蠢。