[ 
https://issues.apache.org/struts/browse/WW-3308?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Lukasz Lenart reassigned WW-3308:
---------------------------------

    Assignee: Lukasz Lenart

> javassist trouble on JBoss 5.1
> ------------------------------
>
>                 Key: WW-3308
>                 URL: https://issues.apache.org/struts/browse/WW-3308
>             Project: Struts 2
>          Issue Type: Bug
>          Components: Other
>    Affects Versions: 2.1.8
>         Environment: JBoss 5.1 GA, Struts 2.1.8
>            Reporter: Mykyta Kostovskyy
>            Assignee: Lukasz Lenart
>            Priority: Critical
>
> While deploying application that contains Struts 2.1.8 get the following 
> error:
> 17:28:34,437 ERROR [BasicLazyInitializer] Javassist Enhancement failed: 
> hello.Message
> java.lang.RuntimeException: java.lang.IllegalArgumentException: Can not set 
> static javassist.util.proxy.MethodFilter field 
> hello.Message_$$_javassist_14._method_filter to 
> org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer$1
>       at javassist.util.proxy.ProxyFactory.setField(ProxyFactory.java:358)
>       at javassist.util.proxy.ProxyFactory.createClass3(ProxyFactory.java:341)
>       at javassist.util.proxy.ProxyFactory.createClass2(ProxyFactory.java:314)
>       at javassist.util.proxy.ProxyFactory.createClass(ProxyFactory.java:273)
>       at 
> org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.getProxyFactory(JavassistLazyInitializer.java:162)
>       at 
> org.hibernate.proxy.pojo.javassist.JavassistProxyFactory.postInstantiate(JavassistProxyFactory.java:66)
>       at 
> org.hibernate.tuple.entity.PojoEntityTuplizer.buildProxyFactory(PojoEntityTuplizer.java:183)
>       at 
> org.hibernate.tuple.entity.AbstractEntityTuplizer.<init>(AbstractEntityTuplizer.java:158)
>       at 
> org.hibernate.tuple.entity.PojoEntityTuplizer.<init>(PojoEntityTuplizer.java:76)
>       at 
> org.hibernate.tuple.entity.EntityEntityModeToTuplizerMapping.<init>(EntityEntityModeToTuplizerMapping.java:80)
>       at 
> org.hibernate.tuple.entity.EntityMetamodel.<init>(EntityMetamodel.java:325)
>       at 
> org.hibernate.persister.entity.AbstractEntityPersister.<init>(AbstractEntityPersister.java:457)
>       at 
> org.hibernate.persister.entity.SingleTableEntityPersister.<init>(SingleTableEntityPersister.java:131)
>       at 
> org.hibernate.persister.PersisterFactory.createClassPersister(PersisterFactory.java:84)
>       at 
> org.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:261)
>       at 
> org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1327)
>       at 
> org.hibernate.cfg.AnnotationConfiguration.buildSessionFactory(AnnotationConfiguration.java:867)
>       at 
> org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:669)
>       at 
> org.hibernate.ejb.HibernatePersistence.createContainerEntityManagerFactory(HibernatePersistence.java:132)
>       at 
> org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.java:224)
>       at 
> org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:291)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1369)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1335)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:473)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
>       at java.security.AccessController.doPrivileged(Native Method)
>       at 
> org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
>       at 
> org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:264)
>       at 
> org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
>       at 
> org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:261)
>       at 
> org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:185)
>       at 
> org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:164)
>       at 
> org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:423)
>       at 
> org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:728)
>       at 
> org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:380)
>       at 
> org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:255)
>       at 
> org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:199)
>       at 
> org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:45)
>       at 
> org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3910)
>       at 
> org.apache.catalina.core.StandardContext.start(StandardContext.java:4393)
>       at 
> org.jboss.web.tomcat.service.deployers.TomcatDeployment.performDeployInternal(TomcatDeployment.java:310)
>       at 
> org.jboss.web.tomcat.service.deployers.TomcatDeployment.performDeploy(TomcatDeployment.java:142)
>       at 
> org.jboss.web.deployers.AbstractWarDeployment.start(AbstractWarDeployment.java:461)
>       at org.jboss.web.deployers.WebModule.startModule(WebModule.java:118)
>       at org.jboss.web.deployers.WebModule.start(WebModule.java:97)
>       at sun.reflect.GeneratedMethodAccessor381.invoke(Unknown Source)
>       at 
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>       at java.lang.reflect.Method.invoke(Method.java:597)
>       at 
> org.jboss.mx.interceptor.ReflectedDispatcher.invoke(ReflectedDispatcher.java:157)
>       at org.jboss.mx.server.Invocation.dispatch(Invocation.java:96)
>       at org.jboss.mx.server.Invocation.invoke(Invocation.java:88)
>       at 
> org.jboss.mx.server.AbstractMBeanInvoker.invoke(AbstractMBeanInvoker.java:264)
>       at org.jboss.mx.server.MBeanServerImpl.invoke(MBeanServerImpl.java:668)
>       at 
> org.jboss.system.microcontainer.ServiceProxy.invoke(ServiceProxy.java:206)
>       at $Proxy38.start(Unknown Source)
>       at 
> org.jboss.system.microcontainer.StartStopLifecycleAction.installAction(StartStopLifecycleAction.java:42)
>       at 
> org.jboss.system.microcontainer.StartStopLifecycleAction.installAction(StartStopLifecycleAction.java:37)
>       at 
> org.jboss.dependency.plugins.action.SimpleControllerContextAction.simpleInstallAction(SimpleControllerContextAction.java:62)
>       at 
> org.jboss.dependency.plugins.action.AccessControllerContextAction.install(AccessControllerContextAction.java:71)
>       at 
> org.jboss.dependency.plugins.AbstractControllerContextActions.install(AbstractControllerContextActions.java:51)
>       at 
> org.jboss.dependency.plugins.AbstractControllerContext.install(AbstractControllerContext.java:348)
>       at 
> org.jboss.system.microcontainer.ServiceControllerContext.install(ServiceControllerContext.java:286)
>       at 
> org.jboss.dependency.plugins.AbstractController.install(AbstractController.java:1631)
>       at 
> org.jboss.dependency.plugins.AbstractController.incrementState(AbstractController.java:934)
>       at 
> org.jboss.dependency.plugins.AbstractController.resolveContexts(AbstractController.java:1082)
>       at 
> org.jboss.dependency.plugins.AbstractController.resolveContexts(AbstractController.java:984)
>       at 
> org.jboss.dependency.plugins.AbstractController.change(AbstractController.java:822)
>       at 
> org.jboss.dependency.plugins.AbstractController.change(AbstractController.java:553)
>       at 
> org.jboss.system.ServiceController.doChange(ServiceController.java:688)
>       at org.jboss.system.ServiceController.start(ServiceController.java:460)
>       at 
> org.jboss.system.deployers.ServiceDeployer.start(ServiceDeployer.java:163)
>       at 
> org.jboss.system.deployers.ServiceDeployer.deploy(ServiceDeployer.java:99)
>       at 
> org.jboss.system.deployers.ServiceDeployer.deploy(ServiceDeployer.java:46)
>       at 
> org.jboss.deployers.spi.deployer.helpers.AbstractSimpleRealDeployer.internalDeploy(AbstractSimpleRealDeployer.java:62)
>       at 
> org.jboss.deployers.spi.deployer.helpers.AbstractRealDeployer.deploy(AbstractRealDeployer.java:50)
>       at 
> org.jboss.deployers.plugins.deployers.DeployerWrapper.deploy(DeployerWrapper.java:171)
>       at 
> org.jboss.deployers.plugins.deployers.DeployersImpl.doDeploy(DeployersImpl.java:1439)
>       at 
> org.jboss.deployers.plugins.deployers.DeployersImpl.doInstallParentFirst(DeployersImpl.java:1157)
>       at 
> org.jboss.deployers.plugins.deployers.DeployersImpl.doInstallParentFirst(DeployersImpl.java:1178)
>       at 
> org.jboss.deployers.plugins.deployers.DeployersImpl.install(DeployersImpl.java:1098)
>       at 
> org.jboss.dependency.plugins.AbstractControllerContext.install(AbstractControllerContext.java:348)
>       at 
> org.jboss.dependency.plugins.AbstractController.install(AbstractController.java:1631)
>       at 
> org.jboss.dependency.plugins.AbstractController.incrementState(AbstractController.java:934)
>       at 
> org.jboss.dependency.plugins.AbstractController.resolveContexts(AbstractController.java:1082)
>       at 
> org.jboss.dependency.plugins.AbstractController.resolveContexts(AbstractController.java:984)
>       at 
> org.jboss.dependency.plugins.AbstractController.change(AbstractController.java:822)
>       at 
> org.jboss.dependency.plugins.AbstractController.change(AbstractController.java:553)
>       at 
> org.jboss.deployers.plugins.deployers.DeployersImpl.process(DeployersImpl.java:781)
>       at 
> org.jboss.deployers.plugins.main.MainDeployerImpl.process(MainDeployerImpl.java:702)
>       at 
> org.jboss.system.server.profileservice.repository.MainDeployerAdapter.process(MainDeployerAdapter.java:117)
>       at 
> org.jboss.system.server.profileservice.hotdeploy.HDScanner.scan(HDScanner.java:362)
>       at 
> org.jboss.system.server.profileservice.hotdeploy.HDScanner.run(HDScanner.java:255)
>       at 
> java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)
>       at 
> java.util.concurrent.FutureTask$Sync.innerRunAndReset(FutureTask.java:317)
>       at java.util.concurrent.FutureTask.runAndReset(FutureTask.java:150)
>       at 
> java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$101(ScheduledThreadPoolExecutor.java:98)
>       at 
> java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.runPeriodic(ScheduledThreadPoolExecutor.java:181)
>       at 
> java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:205)
>       at 
> java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
>       at 
> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
>       at java.lang.Thread.run(Thread.java:619)
> Caused by: java.lang.IllegalArgumentException: Can not set static 
> javassist.util.proxy.MethodFilter field 
> hello.Message_$$_javassist_14._method_filter to 
> org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer$1
>       at 
> sun.reflect.UnsafeFieldAccessorImpl.throwSetIllegalArgumentException(UnsafeFieldAccessorImpl.java:146)
>       at 
> sun.reflect.UnsafeFieldAccessorImpl.throwSetIllegalArgumentException(UnsafeFieldAccessorImpl.java:150)
>       at 
> sun.reflect.UnsafeStaticObjectFieldAccessorImpl.set(UnsafeStaticObjectFieldAccessorImpl.java:61)
>       at java.lang.reflect.Field.set(Field.java:657)
>       at javassist.util.proxy.ProxyFactory.setField(ProxyFactory.java:354)
>       ... 100 more
> This is due to the fact, that xworks-core-2.1.6.jar that is a part of Struts 
> 2.1.8 is delivered with javassist code inside, that conflicts with the one 
> inside of JBoss.
> Please help to resolve the problem, since Struts 2.1.8 does not work with 
> previous versions of xworks.

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.

Reply via email to