java.lang.NoClassDefFoundError: com / sun / mail / util / MailLogger para el caso de prueba JUnit para correo Java

127

Estoy usando Java Mail API para leer y analizar correos electrónicos. Está funcionando bien con el código de Servlet.

Ahora estoy tratando de escribir un caso de prueba JUnit con el mismo propósito. Pero en línea Session session = Session.getDefaultInstance(properties);obtengo la siguiente excepción:

java.lang.NoClassDefFoundError: com/sun/mail/util/MailLogger
    at javax.mail.Session.initLogger(Session.java:227)
    at javax.mail.Session.<init>(Session.java:212)
    at javax.mail.Session.getDefaultInstance(Session.java:315)
    at javax.mail.Session.getDefaultInstance(Session.java:355)
    at com.vxl.appanalytix.dataload.fromEmail.EmailParser.parseEmailSubject(EmailParser.java:44)
    at com.vxl.appanalytix.controllers.controllerClasses.GenericEmailServiceClass.readEmailAttachments(GenericEmailServiceClass.java:33)
    at com.vxl.appanalytix.dataload.GenericEmailTestCase.test(GenericEmailTestCase.java:42)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:45)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:42)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
    at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74)
    at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:83)
    at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72)
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:231)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:47)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222)
    at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
    at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:300)
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:174)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: java.lang.ClassNotFoundException: com.sun.mail.util.MailLogger
    at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
    ... 35 more

¿Alguien puede decirme dónde me estoy equivocando?

usuario2215139
fuente

Respuestas:

116

com.sun.mail.util.MailLoggeres parte de la API JavaMail . Ya está incluido en el entorno EE (por eso puede usarlo en su servidor en vivo), pero no está incluido en el entorno SE.

Documentos de Oracle :

La API JavaMail está disponible como un paquete opcional para usar con la plataforma Java SE y también se incluye en la plataforma Java EE.

99% que ejecuta sus pruebas en el entorno SE, lo que significa lo que tiene que molestarse en agregarlo manualmente a su classpath cuando ejecuta pruebas.

Si está utilizando Maven, agregue la siguiente dependencia (es posible que desee cambiar la versión):

<dependency>
    <groupId>com.sun.mail</groupId>
    <artifactId>javax.mail</artifactId>
    <version>1.6.0</version>
</dependency>
Eugene Loy
fuente
63
El artefacto javax.mail-api solo es bueno para compilar. Realmente necesita ejecutar código, por lo que necesita una implementación completa de JavaMail. Uso <groupId>com.sun.mail</groupId><artifactId>javax.mail</artifactId>.
Bill Shannon
150

El javax.mail-apiartefacto solo es bueno para compilar .

En realidad, necesita ejecutar código, por lo que necesita una implementación completa de la API JavaMail. Utilizar este:

<dependency>
    <groupId>com.sun.mail</groupId>
    <artifactId>javax.mail</artifactId>
    <version>1.6.2</version>
</dependency>

NOTA: El número de versión probablemente diferirá. Consulta la última versión aquí .

Bill Shannon
fuente
3
Esto también corrige java.lang.NoClassDefFoundError: com/sun/mail/util/PropUtil, así como Could not initialize class javax.mail.internet.InternetAddresserrores.
GlenPeterson
1
Se explica en la página web del proyecto JavaMail .
Bill Shannon
52

Utilizo las siguientes dependencias de Maven para que el correo Java funcione. El primero incluye la API javax.mail (sin implementación) y el segundo es la implementación SUN de la API javax.mail.

<dependency>
    <groupId>javax.mail</groupId>
    <artifactId>javax.mail-api</artifactId>
    <version>1.5.5</version>
</dependency>
<dependency>
    <groupId>com.sun.mail</groupId>
    <artifactId>javax.mail</artifactId>
    <version>1.5.5</version>
</dependency>
Shane Rowatt
fuente
9
No necesita incluir la API si tiene la implementación.
GlenPeterson
1
Buen punto @GlenPeterson, no me di cuenta de eso por la solución anterior, pero cuando busqué en el archivo com.sun.mail, la api javax.mail está incluida.
Peter
1

Ocurre también si su código espera Java Mail 1.4 y sus archivos jar son Java Mail 1.3. Me pasó cuando se actualizó Pentaho Kettle

Saludos

Carlos Rafael Ramirez
fuente