FYI https://issues.jboss.org/browse/WELD-1543

On 11/05/2013 07:55 AM, hantsy wrote:
According the info, remove

TransactionalInterceptor

registration in your WEB-INF/beans.xml
and have a try.

Hantsy

On 11/5/2013 14:35, 十三郎 wrote:
  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
-----------------

i filed a issue on jira,

Gerhard Petracek  said:
-----------------------------------

that isn't an issue of deltaspike -> please file a weld portability issue or 
just remove the config entry from your own config.
-----------------------------------





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 email is free from viruses and malware because avast! Antivirus protection 
is active.
http://www.avast.com


Reply via email to