Erro SpringMVC + Maven + Hibernate/JPA

1 resposta
maykoone

fala galera,

estou com um erro bem estranho acontecendo em uma aplicação que estou fazendo para validar algumas tecnologias (expostas no título). Bom, estou usando o Maven
para gerenciar as dependências, não tenho muita experiência com ele. Também estou utilizando o Spring juntamente com o Hibernate e o JPA. Beleza, fiz a parte da perisistência
e a camada de service, e um teste unitário para ver se funcionava, o teste rola perfeito, o problema foi quando eu quiz fazer isso usando a parte web com o Spring MVC, pelo netbeans
eu mando executar o projeto, vejo no console o maven baixando as dependências, rodando os testes com sucesso, mas na hora de rodar a aplicação estoura essa bomba aqui, na hora de criar o EntityManager,
o que eu não entendi, é porque no JUnit ele rola mas rodando a aplicação web não rola.

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor#0' defined in class path resource [META-INF/application-context.xml]: Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'emf' defined in class path resource [META-INF/application-context.xml]: Invocation of init method failed; nested exception is java.lang.NoClassDefFoundError: Could not initialize class org.hibernate.ejb.Ejb3Configuration
	org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:527)
	org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)
	org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:294)
	org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:225)
	org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:291)
	org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197)
	org.springframework.context.support.AbstractApplicationContext.registerBeanPostProcessors(AbstractApplicationContext.java:728)
	org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:449)
	org.springframework.web.servlet.FrameworkServlet.configureAndRefreshWebApplicationContext(FrameworkServlet.java:631)
	org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:588)
	org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:645)
	org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.java:508)
	org.springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.java:449)
	org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:133)
	javax.servlet.GenericServlet.init(GenericServlet.java:160)
	org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
	org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
	org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927)
	org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
	org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:987)
	org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579)
	org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:307)
	java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
	java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
	java.lang.Thread.run(Thread.java:722)

Sei lá, estou achando que é algum conflito de lib do maven, apesar de já ter alterado de tudo quanto é jeito.

Eu coloquei o projeto no github, se alguém quiser dar uma olhada.
https://github.com/maykoone/maven-crud

Alguns arquivos principais:
Maven: https://github.com/maykoone/maven-crud/blob/master/pom.xml
Spring:https://github.com/maykoone/maven-crud/blob/master/src/main/resources/META-INF/application-context.xml
Spring Web: https://github.com/maykoone/maven-crud/blob/master/src/main/webapp/WEB-INF/web-application-context.xml
JUnit: https://github.com/maykoone/maven-crud/blob/master/src/test/java/com/makoone/mavencrud/service/ContatoServiceTest.java

1 Resposta

maykoone

Já descobri o que era!
Não sei se isso é um bug do Netbeans ou sei lá, mas quando ele gerava o artefato para fazer o deploy, ainda existia bibliotecas repetidas do hibernate, mesmo depois de eu arrumar as dependências, descobri isso depois de rodar direto com o plugin do tomcat no maven. Aproveitando, tbm vi que tinhas dependências desnecessárias do servlet.

Bom fica, a dica caso alguém tenha o mesmo problema.

Criado 5 de agosto de 2012
Ultima resposta 5 de ago. de 2012
Respostas 1
Participantes 1