没有这样的属性:org.codehaus.grails.INCLUDED_JS_LIBRARIES

时间:2013-09-23 12:32:58

标签: spring tomcat grails phantomjs grails-2.2

要求

我正在尝试在功能测试阶段的自定义测试阶段运行我的JavaScript测试。基本上它需要:

  • 启动嵌入式Tomcat
  • 打开控制器
  • 检查已执行测试的结果

我做了什么

首先,我根据此post创建了自定义测试阶段。所以我的_Events.groovy看起来像

includeTargets << new File("${basedir}/scripts/_RunJavaScriptUiTests.groovy")

eventConfigureTomcat = { tomcat ->
  tomcat.connector.setAttribute("compression", "on")
  tomcat.connector.setAttribute("compressableMimeType", "text/html,text/xml,text/plain,application/javascript")
  tomcat.connector.port = serverPort
}

eventAllTestsStart = {
  phasesToRun << "uijs"
}

uijsTests = ["uijs"]

uijsTestPhasePreparation = { 
  functionalTestPhasePreparation()
}

uijsTestPhaseCleanUp = { 
  functionalTestPhaseCleanUp()
}
eventTestPhaseEnd = { phase ->
  if( phase == "uijs" ) {
    runJavaScriptUiTests()
  }
}

接下来,我决定使用PhantomJS打开我的页面并分析执行的测试。所以我在 RunJavaScriptUiTests.groovy 脚本中使用了这个

target(runJavaScriptUiTests:"Running Siesta tests") {

    event("StatusUpdate", ["Siesta test phase..."])

    //this is the script that evaluates the result of the tests
    File script = new File("web-app/js/siesta/siesta-phantomjs-runner.js")

    String home = System.getenv("PHANTOMJS_HOME")
    if(!home) {
        throw new RuntimeException("PHANTOMJS_HOME must be set.")
    }

    String executable = "${home}bin${File.separator}phantomjs"
    String port = System.getProperty("server.port","8080")
    String url = "http://localhost:$port/insoft-ext-ui/siesta" //url of my tests

    println "Running Phantomjs ${executable} ${script.absolutePath} "

    try {
        ant.exec(executable: executable, outputproperty: "cmdOut", failonerror: 'true', errorproperty: "cmdErr") {
            arg(value: script.absolutePath)
            arg(value: url)
        }
        }catch(e) {
        println "ERROR: $e"
        throw e
    }

    try {

        String output = "${ant.project.properties.cmdOut}"
        println output

        }catch(e) {
        event("StatusError",["Exception $e"])
    }

}

我可以看到 functionalTestPhasePreparation 运行,因为这会正确启动我的应用程序。我还可以看到phantomjs命令在打印时是正确的:

Running: /desenv/phantomjs-1.9.2/bin/phantomjs /desenv/java/projetos/insoft-ext-ui/web-app/js/siesta/siesta-phantomjs-runner.js http://localhost:8080/insoft-ext-ui/siesta

但这给了我 groovy.lang.MissingPropertyException

groovy.lang.MissingPropertyException: No such property: org.codehaus.grails.INCLUDED_JS_LIBRARIES for class: org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestWrapper
    at org.codehaus.groovy.runtime.ScriptBytecodeAdapter.unwrap(ScriptBytecodeAdapter.java:50)
    at org.codehaus.groovy.runtime.callsite.PojoMetaMethodSite$PojoMetaMethodSiteNoUnwrapNoCoerce.invoke(PojoMetaMethodSite.java:273)
    at org.codehaus.groovy.runtime.callsite.PojoMetaMethodSite.call(PojoMetaMethodSite.java:53)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:45)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:108)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:116)
    at org.codehaus.groovy.grails.web.filters.JavascriptLibraryFilters$_closure1_closure2_closure3.doCall(JavascriptLibraryFilters.groovy:27)
    at org.codehaus.groovy.grails.web.filters.JavascriptLibraryFilters$_closure1_closure2_closure3.doCall(JavascriptLibraryFilters.groovy)
    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)

有关完整的Stacktrace,请参阅here

有趣的是,如果我只是做

grails test run-app
phantomjs /desenv/java/projetos/insoft-ext-ui/web-app/js/siesta/siesta-phantomjs-runner.js http://localhost:8080/insoft-ext-ui/siesta

脚本有效,我没有任何例外。

问题

为什么抛出MissingPropertyException?我查看了 JavascriptLibraryFilters 并没有找到原因。

修改

关于Tomcat

我正在使用Grails附带的嵌入式Tomcat,但在_Events.groovy中启用压缩:

eventConfigureTomcat = { tomcat ->
    tomcat.connector.setAttribute("compression", "on")
    tomcat.connector.setAttribute("compressableMimeType", "text/html,text/xml,text/plain,application/javascript")
    tomcat.connector.port = serverPort
}

1 个答案:

答案 0 :(得分:2)

我没有直接的解决方案,但我可以帮助你研究这个。

您的问题的来源显然是org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestWrapper,它在您的Tomcat环境中应用,这解释了您的代码独立运作的原因。

Stack Overflow上存在引用此相同Spring类的其他问题。其中大多数是关于不正确的多部分请求处理的问题。 这会让我相信PhantomJS正在进行多部分调用而没有针对您的环境进行适当的转换或接口。我怀疑可能需要更改Tomcat或Grails配置。

以下是我提到的几个SO问题:

以下是Grails / CXF上可能存在的相关错误:

  • Spring Security bug,指的是CXF bug,其中说“要在CXF上启用MTOM,您必须通过在{{1中设置选项grails.web.disable.multipart=true来禁用Grails的多部分处理}}“

请提供有关您的Tomcat / Grails设置的任何详细信息和/或确认您已调查这些潜在的问题路径,以便我们可以对其进行折扣。

希望这个答案可以帮助您或其他人找到正确的解决方案。