Uploaded image for project: 'DeltaSpike'
  1. DeltaSpike
  2. DELTASPIKE-436

WELD-001416 Enabled interceptor TransactionalInterceptor specified twice in tomcat8

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Closed
    • Major
    • Resolution: Won't Fix
    • 0.5
    • None
    • JPA-Module
    • None
    • jdk1.7,tomcat8(rc5)

    Description

      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:

      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>

      Attachments

        Activity

          People

            Unassigned Unassigned
            mihaisheng mihaisheng
            Votes:
            0 Vote for this issue
            Watchers:
            4 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: