I have done a bit more digging and somehow, somehwere there is a call to
com.opensymphony.xwork2.inject.ContainerImpl.addInjectors(Class, List<Injector>) the class in arguments list is org.apache.struts2.views.velocity.VelocityManager So somehow xwork is instructed to add injectors to that class. The other mystery is of course why it does not happen with jetty. So, if anyone got some clue as to what needs to be adjusted for an exception to go away (besides adding un-needed dep) I am all ears. Thanks, Alex. On Tue, Mar 18, 2008 at 8:06 AM, Alex Shneyderman <[EMAIL PROTECTED]> wrote: > hmm it seems that there is an unresolved issue: > > https://issues.apache.org/struts/browse/WW-2228 > > any idea beyond what is in the comments? I mean I understand that > sitemesh has velocity as optional jar but it is optional for a reason, > I do not understand why an exception needs to be thrown. > > odd. > > On Tue, Mar 18, 2008 at 7:54 AM, Alex Shneyderman > > <[EMAIL PROTECTED]> wrote: > > > > I get an exception while deploying WAR to WL 10. Here is the stack trace: > > > > java.lang.NoClassDefFoundError: Lorg/apache/velocity/app/VelocityEngine; > > at java.lang.Class.getDeclaredFields0(Native Method) > > at java.lang.Class.privateGetDeclaredFields(Class.java:2259) > > at java.lang.Class.getDeclaredFields(Class.java:1715) > > at > com.opensymphony.xwork2.inject.ContainerImpl.addInjectors(ContainerImpl.java:102) > > at > com.opensymphony.xwork2.inject.ContainerImpl$1.create(ContainerImpl.java:84) > > at > com.opensymphony.xwork2.inject.ContainerImpl$1.create(ContainerImpl.java:82) > > at > com.opensymphony.xwork2.inject.util.ReferenceCache$CallableCreate.call(ReferenceCache.java:155) > > at > java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:269) > > at java.util.concurrent.FutureTask.run(FutureTask.java:123) > > at > com.opensymphony.xwork2.inject.util.ReferenceCache.internalCreate(ReferenceCache.java:81) > > at > com.opensymphony.xwork2.inject.util.ReferenceCache.get(ReferenceCache.java:121) > > at > com.opensymphony.xwork2.inject.ContainerImpl$ConstructorInjector.<init>(ContainerImpl.java:329) > > at > com.opensymphony.xwork2.inject.ContainerImpl$5.create(ContainerImpl.java:299) > > at > com.opensymphony.xwork2.inject.ContainerImpl$5.create(ContainerImpl.java:298) > > at > com.opensymphony.xwork2.inject.util.ReferenceCache$CallableCreate.call(ReferenceCache.java:155) > > at > java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:269) > > at java.util.concurrent.FutureTask.run(FutureTask.java:123) > > at > com.opensymphony.xwork2.inject.util.ReferenceCache.internalCreate(ReferenceCache.java:81) > > at > com.opensymphony.xwork2.inject.util.ReferenceCache.get(ReferenceCache.java:121) > > at > com.opensymphony.xwork2.inject.ContainerImpl.getConstructor(ContainerImpl.java:562) > > at > com.opensymphony.xwork2.inject.ContainerImpl.inject(ContainerImpl.java:460) > > at > com.opensymphony.xwork2.inject.ContainerImpl$7.call(ContainerImpl.java:501) > > at > com.opensymphony.xwork2.inject.ContainerImpl.callInContext(ContainerImpl.java:549) > > at > com.opensymphony.xwork2.inject.ContainerImpl.inject(ContainerImpl.java:499) > > at > com.opensymphony.xwork2.config.impl.LocatableFactory.create(LocatableFactory.java:32) > > at > com.opensymphony.xwork2.inject.ContainerBuilder$4.create(ContainerBuilder.java:134) > > at com.opensymphony.xwork2.inject.Scope$2$1.create(Scope.java:49) > > at > com.opensymphony.xwork2.inject.ContainerImpl$ParameterInjector.inject(ContainerImpl.java:431) > > at > com.opensymphony.xwork2.inject.ContainerImpl.getParameters(ContainerImpl.java:446) > > at > com.opensymphony.xwork2.inject.ContainerImpl.access$000(ContainerImpl.java:48) > > at > com.opensymphony.xwork2.inject.ContainerImpl$MethodInjector.inject(ContainerImpl.java:288) > > at > com.opensymphony.xwork2.inject.ContainerImpl$2.call(ContainerImpl.java:117) > > at > com.opensymphony.xwork2.inject.ContainerImpl$2.call(ContainerImpl.java:115) > > at > com.opensymphony.xwork2.inject.ContainerImpl.callInContext(ContainerImpl.java:542) > > at > com.opensymphony.xwork2.inject.ContainerImpl.injectStatics(ContainerImpl.java:114) > > at > com.opensymphony.xwork2.inject.ContainerBuilder.create(ContainerBuilder.java:494) > > at > com.opensymphony.xwork2.config.impl.DefaultConfiguration.reload(DefaultConfiguration.java:145) > > at > com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:52) > > at > org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:395) > > at > org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:452) > > at > org.apache.struts2.dispatcher.FilterDispatcher.init(FilterDispatcher.java:201) > > at > weblogic.servlet.internal.FilterManager$FilterInitAction.run(FilterManager.java:320) > > at > weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321) > > at weblogic.security.service.SecurityManager.runAs(Unknown Source) > > at > weblogic.servlet.internal.FilterManager.loadFilter(FilterManager.java:88) > > at > weblogic.servlet.internal.FilterManager.preloadFilters(FilterManager.java:57) > > at > weblogic.servlet.internal.WebAppServletContext.preloadResources(WebAppServletContext.java:1725) > > at > weblogic.servlet.internal.WebAppServletContext.start(WebAppServletContext.java:2890) > > at > weblogic.servlet.internal.WebAppModule.startContexts(WebAppModule.java:948) > > at > weblogic.servlet.internal.WebAppModule.start(WebAppModule.java:353) > > at > weblogic.application.internal.flow.ModuleStateDriver$3.next(ModuleStateDriver.java:204) > > at > weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:26) > > at > weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:60) > > at > weblogic.application.internal.flow.ScopedModuleDriver.start(ScopedModuleDriver.java:200) > > at > weblogic.application.internal.flow.ModuleListenerInvoker.start(ModuleListenerInvoker.java:117) > > at > weblogic.application.internal.flow.ModuleStateDriver$3.next(ModuleStateDriver.java:204) > > at > weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:26) > > at > weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:60) > > at > weblogic.application.internal.flow.StartModulesFlow.activate(StartModulesFlow.java:26) > > at > weblogic.application.internal.BaseDeployment$2.next(BaseDeployment.java:635) > > at > weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:26) > > at > weblogic.application.internal.BaseDeployment.activate(BaseDeployment.java:212) > > at > weblogic.application.internal.DeploymentStateChecker.activate(DeploymentStateChecker.java:154) > > at > weblogic.deploy.internal.targetserver.AppContainerInvoker.activate(AppContainerInvoker.java:80) > > at > weblogic.deploy.internal.targetserver.operations.AbstractOperation.activate(AbstractOperation.java:566) > > at > weblogic.deploy.internal.targetserver.operations.ActivateOperation.activateDeployment(ActivateOperation.java:136) > > at > weblogic.deploy.internal.targetserver.operations.ActivateOperation.doCommit(ActivateOperation.java:104) > > at > weblogic.deploy.internal.targetserver.operations.StartOperation.doCommit(StartOperation.java:139) > > at > weblogic.deploy.internal.targetserver.operations.AbstractOperation.commit(AbstractOperation.java:320) > > at > weblogic.deploy.internal.targetserver.DeploymentManager.handleDeploymentCommit(DeploymentManager.java:816) > > at > weblogic.deploy.internal.targetserver.DeploymentManager.activateDeploymentList(DeploymentManager.java:1223) > > at > weblogic.deploy.internal.targetserver.DeploymentManager.handleCommit(DeploymentManager.java:434) > > at > weblogic.deploy.internal.targetserver.DeploymentServiceDispatcher.commit(DeploymentServiceDispatcher.java:161) > > at > weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.doCommitCallback(DeploymentReceiverCallbackDeliverer.java:181) > > at > weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.access$100(DeploymentReceiverCallbackDeliverer.java:12) > > at > weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer$2.run(DeploymentReceiverCallbackDeliverer.java:67) > > at > weblogic.work.SelfTuningWorkManagerImpl$WorkAdapterImpl.run(SelfTuningWorkManagerImpl.java:464) > > at weblogic.work.ExecuteThread.execute(ExecuteThread.java:200) > > at weblogic.work.ExecuteThread.run(ExecuteThread.java:172) > > > > > > The project is built with maven and when I deploy with jetty:run > > everything work Ok. This is my dependency:tree output: > > > > ... > > [INFO] [dependency:tree] > > [INFO] mypackage:webclient:war:0.5-SNAPSHOT > > [INFO] +- org.testng:testng:jar:jdk15:5.6:test > > [INFO] | \- junit:junit:jar:3.8.1:test > > [INFO] +- org.apache.struts:struts2-core:jar:2.0.11:compile > > [INFO] | +- com.opensymphony:xwork:jar:2.0.4:compile > > [INFO] | +- commons-logging:commons-logging:jar:1.0.4:compile > > [INFO] | +- opensymphony:ognl:jar:2.6.11:compile > > [INFO] | +- freemarker:freemarker:jar:2.3.8:compile > > [INFO] | \- com.sun:tools:jar:1.5.0:system > > [INFO] +- org.apache.struts:struts2-spring-plugin:jar:2.0.11:compile > > [INFO] | +- org.springframework:spring-beans:jar:2.0.5:compile > > [INFO] | +- org.springframework:spring-core:jar:2.0.5:compile > > [INFO] | +- org.springframework:spring-context:jar:2.0.5:compile > > [INFO] | | \- aopalliance:aopalliance:jar:1.0:compile > > [INFO] | \- org.springframework:spring-web:jar:2.0.5:compile > > [INFO] +- org.apache.struts:struts2-sitemesh-plugin:jar:2.0.11:compile > > [INFO] | \- opensymphony:sitemesh:jar:2.2.1:compile > > [INFO] +- org.apache.struts:struts2-codebehind-plugin:jar:2.0.11:compile > > [INFO] +- javax.servlet:servlet-api:jar:2.4:provided > > [INFO] +- javax.servlet:jsp-api:jar:2.0:provided > > [INFO] +- commons-fileupload:commons-fileupload:jar:1.1.1:compile > > [INFO] | \- commons-io:commons-io:jar:1.1:compile > > ... > > > > Doe anyone have a clue as to what's going on with this? > > > > TIA, > > Alex. > > > --------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]