【发布时间】:2015-12-15 11:47:14
【问题描述】:
我正在尝试使用 maven tomcat 插件在同一构建中运行两组集成测试(两个不同的模块)。第一组在第一个模块上完美运行。但是tomcat无法为第二个模块部署战争。而是给出以下异常
com.sun.faces.config.ConfigureListener contextInitialized
SEVERE: Critical error during deployment:
com.sun.faces.config.ConfigurationException: java.util.concurrent.ExecutionException: com.sun.faces.config.ConfigurationException: Unable to parse document 'jndi:/localhost/test-module2/WEB-INF/faces-config.xml': Illegal class loader binding
at com.sun.faces.config.ConfigManager.getConfigDocuments(ConfigManager.java:760)
at com.sun.faces.config.ConfigManager.initialize(ConfigManager.java:349)
at com.sun.faces.config.ConfigureListener.contextInitialized(ConfigureListener.java:214)
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:5014)
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5524)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1575)
at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1565)
at java.util.concurrent.FutureTask.run(FutureTask.java:262)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:745)
Caused by: java.util.concurrent.ExecutionException: com.sun.faces.config.ConfigurationException: Unable to parse document 'jndi:/localhost/test-module2/WEB-INF/faces-config.xml': Illegal class loader binding
at java.util.concurrent.FutureTask.report(FutureTask.java:122)
at java.util.concurrent.FutureTask.get(FutureTask.java:188)
at com.sun.faces.config.ConfigManager.getConfigDocuments(ConfigManager.java:758)
... 11 more
Caused by: com.sun.faces.config.ConfigurationException: Unable to parse document 'jndi:/localhost/test-module2/WEB-INF/faces-config.xml': Illegal class loader binding
at com.sun.faces.config.ConfigManager$ParseTask.call(ConfigManager.java:1009)
at com.sun.faces.config.ConfigManager$ParseTask.call(ConfigManager.java:953)
at java.util.concurrent.FutureTask.run(FutureTask.java:262)
at com.sun.faces.config.ConfigManager.getConfigDocuments(ConfigManager.java:746)
... 11 more
Caused by: java.lang.IllegalStateException: Illegal class loader binding
at org.apache.naming.resources.DirContextURLStreamHandler.get(DirContextURLStreamHandler.java:228)
at org.apache.naming.resources.DirContextURLStreamHandler.openConnection(DirContextURLStreamHandler.java:90)
at java.net.URL.openConnection(URL.java:971)
at com.sun.faces.config.ConfigManager$ParseTask.getInputStream(ConfigManager.java:1230)
at com.sun.faces.config.ConfigManager$ParseTask.getDocument(ConfigManager.java:1030)
at com.sun.faces.config.ConfigManager$ParseTask.call(ConfigManager.java:1000)
... 14 more
两个maven项目的pom.xml中的插件配置如下:
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.3-SNAPSHOT</version>
<configuration>
<path>/test-module2</path>
<port>8081</port>
</configuration>
<executions>
<execution>
<id>start-tomcat</id>
<phase>pre-integration-test</phase>
<goals>
<goal>run</goal>
</goals>
<configuration>
<fork>true</fork>
</configuration>
</execution>
<execution>
<id>stop-tomcat</id>
<phase>post-integration-test</phase>
<goals>
<goal>shutdown</goal>
</goals>
</execution>
</executions>
</plugin>
有人知道为什么会发生这个错误吗?
【问题讨论】:
-
显然 gradle 插件有同样的问题github.com/bmuschko/gradle-tomcat-plugin/issues/46,github.com/bmuschko/gradle-tomcat-plugin/issues/124,可能与 tomcat 内部有关,正如线程中有人建议的那样。迁移到 jetty maven 插件的选项?
标签: java maven tomcat maven-tomcat-plugin