[ https://issues.apache.org/jira/browse/DELTASPIKE-436?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13813763#comment-13813763 ]
Jozef Hartinger commented on DELTASPIKE-436: -------------------------------------------- https://issues.jboss.org/browse/WELD-1543 > WELD-001416 Enabled interceptor TransactionalInterceptor specified twice in > tomcat8 > ----------------------------------------------------------------------------------- > > Key: DELTASPIKE-436 > URL: https://issues.apache.org/jira/browse/DELTASPIKE-436 > Project: DeltaSpike > Issue Type: Bug > Components: JPA-Module > Affects Versions: 0.5 > Environment: jdk1.7,tomcat8(rc5) > Reporter: mihaisheng > > i write a jpa demo,and this demo work fined in jboss-as7.1.1.final. > i want to make it worked in tomcat8. > after depolyed the war to tomcat,the error occurred. > ----------------- > org.jboss.weld.exceptions.DeploymentException: WELD-001416 Enabled > interceptor class > org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor specified > twice: > - > <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class> > in file:/d:/Tomcat%208.0rc5/temp/9-prog_tomcat/WEB-INF/beans.xml@5, > - > <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class> > in > jar:file:/D:/Tomcat%208.0rc5/temp/9-prog_tomcat/WEB-INF/lib/deltaspike-jpa-module-impl-0.5.jar!/META-INF/beans.xml@24 > ----------------- > im sure this demo work fined in jboss-as7.1.1.final. > 1.EntityManagerProducer > --- > public class EntityManagerProducer > { > @PersistenceContext(unitName = "persistence0") > private EntityManager entityManager; > @Produces > @SessionScoped > protected EntityManager createEntityManager() > { > return this.entityManager; > } > protected void closeEntityManager(@Disposes EntityManager entityManager) > { > if (entityManager.isOpen()) > { > entityManager.close(); > } > } > } > --- > 2.do some database transactional work in a @Transactional way > --- > import java.io.Serializable; > import javax.enterprise.context.SessionScoped; > import javax.inject.Inject; > import javax.inject.Named; > import javax.persistence.EntityManager; > import javax.persistence.Query; > import org.apache.deltaspike.core.api.provider.BeanProvider; > import org.apache.deltaspike.jpa.api.transaction.Transactional; > @Named > @SessionScoped > @Transactional > public class Test implements Serializable > { > private static final long serialVersionUID = -1231439157655757940L; > @Inject CurrentUser currentUser; > @Transactional > public String test1(){ > EntityManager > entityManager0=BeanProvider.getContextualReference(EntityManager.class,false); > //just fill some test data to database > String sql="insert into grandscape_user > (user_name,user_password) values (:u,:p)"; > Query query=entityManager0.createNativeQuery(sql); > query.setParameter("u", "Jason Porter"); > query.setParameter("p", "secrete"); > query.executeUpdate(); > return "success"; > } > } > --- > 3.persistence.xml > --- > <?xml version="1.0" encoding="UTF-8"?> > <persistence xmlns="http://java.sun.com/xml/ns/persistence" > xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" > xsi:schemaLocation="http://java.sun.com/xml/ns/persistence > http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd" > version="2.0"> > <persistence-unit name="persistence0" transaction-type="RESOURCE_LOCAL"> > > <provider>org.hibernate.ejb.HibernatePersistence</provider> > <non-jta-data-source>java:comp/env/jdbc/MysqlDB</non-jta-data-source> > <properties> > <property name="hibernate.connection.driver_class" > value="com.mysql.jdbc.Driver"/> > <property name="hibernate.connection.url" > value="jdbc:mysql://localhost:3306/grandscape_websit/"></property> > <property name="hibernate.connection.username" > value="root" /> > <property name="hibernate.connection.password" > value="root" /> > <property name="hibernate.dialect" > value="org.hibernate.dialect.MySQLInnoDBDialect"/> > <property name="hibernate.connection.autocommit" value="true" /> > <property name="hibernate.hbm2ddl.auto" value="validate"/> > <property name="hibernate.show_sql" value="false"/> > <property name="hibernate.cache.use_second_level_cache" > value="true"/> > <property name="hibernate.cache.provider_class" > value="net.sf.ehcache.hibernate.SingletonEhCacheProvider"/> > <property name="hibernate.search.default.directory_provider" > value="org.hibernate.search.store.FSDirectoryProvider"/> > <property name="hibernate.search.default.indexBase" > value="./lucene/indexes"/> > <property name="hibernate.search.default.batch.merge_factor" > value="10"/> > <property name="hibernate.search.default.batch.max_buffered_docs" > value="10"/> > </properties> > </persistence-unit> > </persistence> > --- > 4.bean.xml > --- > <?xml version="1.0" encoding="UTF-8"?> > <beans xmlns="http://java.sun.com/xml/ns/javaee" > xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" > xsi:schemaLocation="http://java.sun.com/xml/ns/javaee > http://java.sun.com/xml/ns/javaee/beans_1_0.xsd"> > <interceptors> > > <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class> > </interceptors> > </beans> > --- > 5.when i deployed the program to tomcat,the error occured. > ----- > 29-Oct-2013 18:05:16.536 SEVERE [localhost-startStop-1] > org.apache.catalina.core.StandardContext.listenerStart Exception sending > context initialized event to listener instance of class > org.jboss.weld.environment.servlet.Listener > org.jboss.weld.exceptions.DeploymentException: WELD-001416 Enabled > interceptor class > org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor specified > twice: > - > <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class> > in > jar:file:/D:/Tomcat%208.0rc5/temp/0-prog_tomcat/WEB-INF/lib/deltaspike-jpa-module-impl-0.5.jar!/META-INF/beans.xml@24, > - > <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class> > in file:/d:/Tomcat%208.0rc5/temp/0-prog_tomcat/WEB-INF/beans.xml@5 > at > org.jboss.weld.bootstrap.enablement.GlobalEnablementBuilder.checkForDuplicates(GlobalEnablementBuilder.java:249) > at > org.jboss.weld.bootstrap.enablement.GlobalEnablementBuilder.createModuleEnablement(GlobalEnablementBuilder.java:226) > at > org.jboss.weld.bootstrap.BeanDeployment.createEnabled(BeanDeployment.java:221) > at > org.jboss.weld.bootstrap.WeldBootstrap.startInitialization(WeldBootstrap.java:488) > at > org.jboss.weld.environment.servlet.Listener.contextInitialized(Listener.java:141) > at > org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4830) > at > org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5276) > at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) > at > org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726) > at > org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702) > at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698) > at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968) > at > org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1742) > at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) > at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source) > at java.util.concurrent.FutureTask.run(Unknown Source) > at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) > at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) > at java.lang.Thread.run(Unknown Source) > 29-Oct-2013 18:05:17.174 SEVERE [localhost-startStop-1] > org.apache.catalina.core.StandardContext.listenerStop Exception sending > context destroyed event to listener instance of class > org.jboss.weld.environment.servlet.Listener > java.lang.NullPointerException > at > org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76) > at > org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30) > at > org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86) > at > org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871) > at > org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499) > at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232) > at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160) > at > org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726) > at > org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702) > at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698) > at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968) > at > org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1742) > at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) > at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source) > at java.util.concurrent.FutureTask.run(Unknown Source) > at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) > at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) > at java.lang.Thread.run(Unknown Source) > ----- > 6.when i remove this block from bean.xml > ------ > <interceptors> > > <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class> > </interceptors> > ------ > the error message occured. > ----- > 29-Oct-2013 18:57:40.366 SEVERE [localhost-startStop-1] > org.apache.catalina.core.StandardContext.listenerStart Exception sending > context initialized event to listener instance of class > org.jboss.weld.environment.servlet.Listener > org.jboss.weld.exceptions.DeploymentException: WELD-001408 Unsatisfied > dependencies for type TransactionStrategy with qualifiers @Default > at injection point [BackedAnnotatedField] @Inject private > org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy > at > org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy(TransactionalInterceptor.java:0) > at > org.jboss.weld.bootstrap.Validator.validateInjectionPointForDeploymentProblems(Validator.java:405) > at > org.jboss.weld.bootstrap.Validator.validateInjectionPoint(Validator.java:327) > at > org.jboss.weld.bootstrap.Validator.validateInterceptor(Validator.java:565) > at > org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:88) > at > org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:86) > at > org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60) > at > org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53) > at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source) > at java.util.concurrent.FutureTask.run(Unknown Source) > at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) > at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) > at java.lang.Thread.run(Unknown Source) > 29-Oct-2013 18:57:41.237 SEVERE [localhost-startStop-1] > org.apache.catalina.core.StandardContext.listenerStop Exception sending > context destroyed event to listener instance of class > org.jboss.weld.environment.servlet.Listener > java.lang.NullPointerException > at > org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76) > at > org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30) > at > org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86) > at > org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871) > at > org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499) > at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232) > at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160) > at > org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726) > at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702) > at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698) > at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968) > at > org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1742) > at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) > at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source) > at java.util.concurrent.FutureTask.run(Unknown Source) > at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) > at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) > at java.lang.Thread.run(Unknown Source) > ---- > my pom.xml > ------ > <?xml version="1.0"?> > <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 > http://maven.apache.org/xsd/maven-4.0.0.xsd" > xmlns="http://maven.apache.org/POM/4.0.0" > xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> > <modelVersion>4.0.0</modelVersion> > <groupId>grandscape</groupId> > <artifactId>prog_tomcat</artifactId> > <version>0.0.1-SNAPSHOT</version> > <packaging>war</packaging> > <name>prog_tomcat Maven Webapp</name> > <url>http://maven.apache.org</url> > > <properties> > <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> > <deltaspike.version>0.5</deltaspike.version> > <picketlink.version>2.5.2.Final</picketlink.version> > </properties> > <dependencies> > <dependency> > <groupId>junit</groupId> > <artifactId>junit</artifactId> > <version>4.11</version> > <scope>test</scope> > </dependency> > <dependency> > <groupId>com.sun.faces</groupId> > <artifactId>jsf-api</artifactId> > <version>2.2.4</version> > </dependency> > <dependency> > <groupId>com.sun.faces</groupId> > <artifactId>jsf-impl</artifactId> > <version>2.2.4</version> > </dependency> > <dependency> > <groupId>javax.enterprise</groupId> > <artifactId>cdi-api</artifactId> > <version>1.1</version> > </dependency> > <dependency> > <groupId>org.jboss.weld.servlet</groupId> > <artifactId>weld-servlet</artifactId> > <version>2.0.4.Final</version> > </dependency> > <dependency> > <groupId>log4j</groupId> > <artifactId>log4j</artifactId> > <version>1.2.17</version> > <scope>compile</scope> > </dependency> > <dependency> > <groupId>org.slf4j</groupId> > <artifactId>slf4j-api</artifactId> > <version>1.7.5</version> > <scope>compile</scope> > </dependency> > <dependency> > <groupId>org.slf4j</groupId> > <artifactId>slf4j-log4j12</artifactId> > <version>1.7.5</version> > <scope>compile</scope> > </dependency> > > <dependency> > <groupId>commons-logging</groupId> > <artifactId>commons-logging</artifactId> > <version>1.1.3</version> > </dependency> > <dependency> > <groupId>org.apache.deltaspike.core</groupId> > <artifactId>deltaspike-core-api</artifactId> > <version>${deltaspike.version}</version> > <scope>compile</scope> > </dependency> > <dependency> > <groupId>org.apache.deltaspike.core</groupId> > <artifactId>deltaspike-core-impl</artifactId> > <version>${deltaspike.version}</version> > <scope>runtime</scope> > </dependency> > <dependency> > <version>1.0.1.Final</version> > <groupId>org.hibernate.javax.persistence</groupId> > <artifactId>hibernate-jpa-2.0-api</artifactId> > <scope>provided</scope> > </dependency> > > <dependency> > <groupId>org.hibernate</groupId> > <artifactId>hibernate-core</artifactId> > <version>4.2.6.Final</version> > </dependency> > <dependency> > <groupId>org.apache.deltaspike.modules</groupId> > <artifactId>deltaspike-jpa-module-api</artifactId> > <version>${deltaspike.version}</version> > <scope>compile</scope> > </dependency> > <dependency> > <groupId>org.apache.deltaspike.modules</groupId> > <artifactId>deltaspike-jpa-module-impl</artifactId> > <version>${deltaspike.version}</version> > <scope>runtime</scope> > </dependency> > </dependencies> > <repositories> > <repository> > <id>people.apache.snapshots</id> > <url> > http://repository.apache.org/content/groups/snapshots-group/ > </url> > <releases> > <enabled>false</enabled> > </releases> > <snapshots> > <enabled>true</enabled> > </snapshots> > </repository> > </repositories> > <pluginRepositories> <pluginRepository> > <id>apache.snapshots</id> > <name>Apache Snapshots</name> > <url> > http://repository.apache.org/content/groups/snapshots-group/ > </url> > <releases> > <enabled>false</enabled> > </releases> > <snapshots> > <enabled>true</enabled> > </snapshots> > </pluginRepository></pluginRepositories> > <build> > <finalName>prog_tomcat</finalName> > <plugins> > <plugin> > <groupId>org.apache.tomcat.maven</groupId> > <artifactId>tomcat7-maven-plugin</artifactId> > <version>2.1</version> > <configuration> > <server>mytomcat</server> > <url>http://localhost:8080/manager/text</url> > <contextReloadable>true</contextReloadable> > </configuration> > </plugin> > </plugins> > </build> > </project> -- This message was sent by Atlassian JIRA (v6.1#6144)