You are viewing a plain text version of this content. The canonical link for it is here.
Posted to users@deltaspike.apache.org by 十三郎 <mi...@163.com> on 2013/11/05 07:35:01 UTC

a weld portability issue on tomcat(7or8)

 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>


Re: a weld portability issue on tomcat(7or8)

Posted by Jozef Hartinger <jh...@redhat.com>.
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
>


Re: a weld portability issue on tomcat(7or8)

Posted by hantsy <ha...@aliyun.com>.
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