[jbossseam-issues] [JBoss JIRA] Commented: (JBSEAM-1636) Cannot inject Spring-bound HibernateSessionFactory to Seam-managed Hibernate Session
Przemyslaw Jaskierski (JIRA)
jira-events at lists.jboss.org
Tue Jul 10 16:52:31 EDT 2007
[ http://jira.jboss.com/jira/browse/JBSEAM-1636?page=comments#action_12368472 ]
Przemyslaw Jaskierski commented on JBSEAM-1636:
-----------------------------------------------
Yes. Declaring it as a Seam component I wanted to accomplish:
<persistence:managed-hibernate-session name="seamManagedHibernateSession" auto-create="true"
session-factory="#{pecpHibernateSessionFactory}"/>
in components.xml. Without this managed-hibernate-session tries to search in JNDI because no such component can be resolved using EL (note: I think that this is alternate approach to using Spring EL resolver and I'm not enabling it in this case).
BTW Sorry for component naming inconsistencies in examples above - I tried to make my descriptors cleaner.
> Cannot inject Spring-bound HibernateSessionFactory to Seam-managed Hibernate Session
> ------------------------------------------------------------------------------------
>
> Key: JBSEAM-1636
> URL: http://jira.jboss.com/jira/browse/JBSEAM-1636
> Project: JBoss Seam
> Issue Type: Bug
> Components: Spring
> Environment: Tomcat 6.0.13, Spring 2.0.6, Seam CVS 08072007
> Reporter: Przemyslaw Jaskierski
> Assigned To: Michael Youngstrom
> Priority: Minor
> Attachments: seamComponentNamespaceStackTrace.txt.zip, springELResolverStackTrace.txt.zip, springStartedFromSeam.txt.zip
>
>
> Filling this PR as requested by Mike.
> For a full story please read related topic. As you requested I tried to reproduce environment from my previous unsuccessful attempts. It's a little bit frustrating but after assembling it once again now Spring EL resolver seams to working somewhat in some aspects. But let's try to report step by step.
> 1. Spring-EL approach: Spring-bound session factory, referenced in components, Spring EL resolver put into faces-config. There are two cases:
> 1.a. I have Seam-session-scoped bean that in @Create tries to get Hibernate session and retrieve some information from RDBMS. I have abstracted Seam-managed-hibernate-session access, and this additional layer simply invokes Component.instance(NAME_OF_SEAM_MANAGED_HIBERNATE_SESSION_COMPONENT_DECLARED_IN_COMPONENTSXML) instead of relying in @In. This layer is completely pluggable and allows to select HibernateSession manager (Seam, Spring OSIV, custom one for Test) and inject it into data access layer.
> Ok, so this @Create call renders a bunch of extremely huge stacktreace (WORKED in Microncontainer/Seam 1.3 combo flawlessly). You can see these stracktraces in springELResolverStackTrace.txt.zip file.
> 1.b. Every following HibernateSession access seams to WORK now (I swear It didn't :(). Strange... Anyway I cannot use it because of 1.a.
> 1.1 components.xml
> <persistence:managed-hibernate-session name="seamManagedHibernateSession" auto-create="true"
> session-factory="#{hibernateSessionFactory}"/>
> <transaction:hibernate-transaction session="#{seamManagedHibernateSession}"/>
> 2. Spring namespace approach: Spring-bound session factory, referenced in components.xml, <seam:component> added to Factory definition in application context:
> <bean id="pecpHibernateSessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean" scope="prototype">
> <seam:component class="org.hibernate.impl.SessionFactoryImpl"/>
> <property name="dataSource" ref="dataSource" />
> <property name="configLocation" value="classpath:conf/hibernate/hibernate.cfg.xml" />
> <property name="configurationClass" value="org.hibernate.cfg.AnnotationConfiguration"/>
> <property name="namingStrategy">
> <bean class="egd.persistence.hibernate.extensions.UnderscoreAwareNamingStrategy"/>
> </property>
> </bean>
> Spring listener put AFTER Seam listener in web.xml. App contexts configured from Spring listener. Result: java.lang.IllegalStateException: No active application scope. See seamComponentNamespaceStackTrace.txt.zip.
> 2.1. components.xml like in 1.1.
> 3. <spring:context-loader> approach. Everything like in point 2., but Spring listener removed from web.xml.
> Result: "Seam cannot wrap JDK proxied IoC beans. Please use CGLib or Javassist proxying instead" - stracktrace in
> springStartedFromSeam.txt.zip
> 3.1. components.xml
> <core:init transaction-management-enabled="true" debug="true"/>
> <core:manager conversation-timeout="120000"
> concurrent-request-timeout="500"
> conversation-id-parameter="k"/>
> <spring:context-loader config-locations="classpath:conf/spring/core.xml,
> classpath:conf/spring/persistence-common.xml,
> classpath:conf/spring/persistence-hibernate.xml,
> classpath:conf/spring/statistics.xml"/>
> <persistence:managed-hibernate-session name="seamManagedHibernateSession" auto-create="true"
> session-factory="#{hibernateSessionFactory}"/>
> <transaction:hibernate-transaction session="#{seamManagedHibernateSession}"/>
> That's all info I can get about this. Having a model example of such integration that I was struggling with would be a quite nice POC.
> Now I need to get back to code, because I lost a lot of time lately :). Will happy live with my current workaround for a while :).
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: http://jira.jboss.com/jira/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the seam-issues
mailing list