Где я могу найти полный пример плагина Maven Cargo для тестов EJB?
Для тестирования некоторых небольших корпоративных приложений JBoss я хотел бы использовать JUnit и плагин Maven Cargo. (Я знаю, что есть и JSFUnit, но сначала я бы хотел поближе взглянуть на Cargo.)
Есть ли простой онлайн-пример, который я мог бы использовать в качестве справочного материала для запуска теста JUnit, который вызывает операцию EJB с использованием JBoss (4.2 или 5.1) с использованием плагина Maven Cargo? Я нашел несколько хороших введений в конфигурацию, но я получаю сообщения об ошибках в поиске EJB, поэтому было бы полезно посмотреть, как его следует использовать.
Вот тестовый код с использованием InitialContext:
public void testEcho() {
assertEquals("Echo Echo", lookupEchoBeanRemote().Echo("Echo"));
}
private EchoBeanRemote lookupEchoBeanRemote() {
try {
Context c = new InitialContext();
return (EchoBeanRemote) c.lookup("EchoBean/remote");
} catch (NamingException ne) {
Logger.getLogger(getClass().getName()).log(Level.SEVERE, "exception caught", ne);
throw new RuntimeException(ne);
}
}
Что дает эту ошибку:
testEcho(de.betabeans.Echo2Test) Time elapsed: 0.885 sec <<< ERROR!
java.lang.reflect.UndeclaredThrowableException
at $Proxy3.Echo(Unknown Source)
at de.betabeans.Echo2Test.testEcho(Echo2Test.java:17)
Caused by: java.security.PrivilegedActionException: java.lang.reflect.InvocationTargetException
at java.security.AccessController.doPrivileged(Native Method)
at org.jboss.ejb3.security.client.SecurityActions.createSecurityContext(SecurityActions.java:657)
at org.jboss.ejb3.security.client.SecurityClientInterceptor.invoke(SecurityClientInterceptor.java:59)
at org.jboss.aop.joinpoint.MethodInvocation.invokeNext(MethodInvocation.java:102)
at org.jboss.ejb3.remoting.IsLocalInterceptor.invoke(IsLocalInterceptor.java:74)
at org.jboss.aop.joinpoint.MethodInvocation.invokeNext(MethodInvocation.java:102)
at org.jboss.aspects.remoting.PojiProxy.invoke(PojiProxy.java:62)
at $Proxy4.invoke(Unknown Source)
at org.jboss.ejb3.proxy.impl.handler.session.SessionProxyInvocationHandlerBase.invoke(SessionProxyInvocationHandlerBase.java:207)
at org.jboss.ejb3.proxy.impl.handler.session.SessionProxyInvocationHandlerBase.invoke(SessionProxyInvocationHandlerBase.java:164)
... 28 more
Caused by: java.lang.reflect.InvocationTargetException
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
at org.jboss.security.SecurityContextFactory.createSecurityContext(SecurityContextFactory.java:117)
at org.jboss.security.SecurityContextFactory.createSecurityContext(SecurityContextFactory.java:76)
at org.jboss.ejb3.security.client.SecurityActions$1.run(SecurityActions.java:662)
... 38 more
Caused by: java.lang.ClassFormatError: Absent Code attribute in method that is not native or abstract in class file javax/security/jacc/PolicyContextException
at java.lang.ClassLoader.defineClass1(Native Method)
Если я использую аннотацию EJB
@EJB(beanInterface=EchoBeanRemote.class,mappedName="EchoBean/remote")
private EchoBeanRemote newSessionBean;
public Echo3Test(String testName) {
super(testName);
}
public void testEcho() {
assertEquals("Echo Echo", newSessionBean.Echo("Echo"));
}
Результат теста
testEcho(de.betabeans.Echo3Test) Time elapsed: 0.001 sec <<< ERROR!
java.lang.NullPointerException
at de.betabeans.Echo3Test.testEcho(Echo3Test.java:20)
jndi.properties находится в корневой папке jar EJB и содержит следующие строки:
java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
java.naming.factory.url.pkgs=org.jboss.naming:org.jnp.interfaces
java.naming.provider.url=jnp://localhost:1099
### The TimedSocketFactory connection timeout in milliseconds (0 == blocking)
jnp.timeout=0
### The TimedSocketFactory read timeout in milliseconds (0 == blocking)
jnp.sotimeout=0
Исходный код компонента
package de.betabeans;
import javax.ejb.Remote;
@Remote
public interface EchoBeanRemote {
String Echo(final String in);
}
package de.betabeans;
import javax.ejb.Stateless;
@Stateless
public class EchoBean implements EchoBeanRemote {
public String Echo(final String in) {
return in + " " + in;
}
}
Я также протестировал веб-приложение, которое может без проблем вызывать EJB - в обоих направлениях, с InitialContext или аннотацией. Предупреждение, которое я получил при развертывании веб-приложения, было
ПРЕДУПРЕЖДЕНИЕ [MappedReferenceMetaDataResolverDeployer] В JBossWebMetaData существуют неразрешенные ссылки:[#web-app:AnnotatedEJBReferenceMetaData{name=de.betabeans.Echo3Servlet/echoBean,ejb-ref-type=null, игнорировать-mall-jund = mall-jound = null, link-null = null, link-nude = null, link-nude = null, link-nude = null, link-nude = null, link-null = null, link-nude = null, link-nude = null, link-nude = null, link-nude = null, link-nude = null, link-nude = null, link-nude = null, link-nude = null, link-nude = null, link-null = null, link-nude = null, link-nude = null, link-nude = null, link-nude = null, link-nude = null, link-null = null, link-nude name=EchoBean/remote,resolved-jndi-name=null,beanInterface=interface de.betabeans.EchoBeanRemote}, #web-app:AnnotatedEJBReferenceMetaData{name=NewServlet/newSessionBean,ejb-ref-type=null, ссылка = null, ссылка = null -dependecy=false, сопоставленный /jndi-name=NewSessionBean/remote,resolved-jndi-name=null,beanInterface=interface de.betabeans.NewSessionBeanRemote}] 12:26:11,770 ИНФО
Все тесты выполнялись с использованием JBoss 5.1.0.GA на двух разных системах сборки.
Я загрузил весь проект Maven прямо сейчас на http://www.mikejustin.com/download/JBossSimpleEJBApp-ejb-test.zip
1 ответ
РЕДАКТИРОВАТЬ: после добавления источников
Прежде всего - мой пример работает на JBoss 4.2.3.GA и Cargo 1.0. Я провел некоторый рефакторинг вашего кода:
файл pom.xml
<groupId>de.betabeans</groupId>
<artifactId>JBossSimpleEJBApp-ejb-test</artifactId>
<packaging>ejb</packaging>
<version>1.0-SNAPSHOT</version>
<name>JBossSimpleEJBApp-ejb JEE5 EJB Test</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>javax.ejb</groupId>
<artifactId>ejb-api</artifactId>
<version>3.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>jboss</groupId>
<artifactId>jboss-ejb3</artifactId>
<version>4.2.3.GA</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.jboss.client</groupId>
<artifactId>jbossall-client</artifactId>
<version>4.2.3.GA</version>
<scope>test</scope>
</dependency>
</dependencies>
<repositories>
<repository>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
<updatePolicy>always</updatePolicy>
</snapshots>
<id>repository.jboss.com</id>
<name>Jboss Repository for Maven</name>
<url>http://repository.jboss.com/maven2/</url>
<layout>default</layout>
</repository>
</repositories>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.0.2</version>
<configuration>
<source>1.5</source>
<target>1.5</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-ejb-plugin</artifactId>
<version>2.1</version>
<configuration>
<ejbVersion>3.0</ejbVersion>
</configuration>
</plugin>
<plugin>
<groupId>org.codehaus.cargo</groupId>
<artifactId>cargo-maven2-plugin</artifactId>
<version>1.0</version>
<configuration>
<container>
<containerId>jboss42x</containerId>
<home>${jboss.home}</home>
<append>false</append>
</container>
<configuration>
<type>existing</type>
<home>${jboss.home}/server/default</home>
<properties>
<cargo.jboss.configuration>default</cargo.jboss.configuration>
<cargo.rmi.port>1099</cargo.rmi.port>
<cargo.logging>high</cargo.logging>
</properties>
</configuration>
<wait>false</wait>
</configuration>
<executions>
<execution>
<id>start-container</id>
<phase>pre-integration-test</phase>
<goals>
<goal>start</goal>
</goals>
</execution>
<execution>
<id>stop-container</id>
<phase>post-integration-test</phase>
<goals>
<goal>stop</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<skip>true</skip>
</configuration>
<executions>
<execution>
<id>surefire-it</id>
<phase>integration-test</phase>
<goals>
<goal>test</goal>
</goals>
<configuration>
<skip>false</skip>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
<finalName>JBossSimpleEJBApp-ejb-test</finalName>
</build>
Я изменил ваш пом в следующих разделах:
- зависимости (вы используете ejb-api от glasfish)
- репозитории (я рекомендую использовать JBoss Maven2 в макете по умолчанию)
- версия и контейнерный идентификатор Cargo-Maven2-плагин
Я переместил папку ресурсов в тестовую папку
Файл jndi.properties должен использоваться тестом (не bean-компонентами) и может быть следующим или имеющимся у вас:
java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
java.naming.factory.url.pkgs=org.jboss.naming:org.jnp.interfaces
java.naming.provider.url=localhost
Другие файлы конфигурации (jboss.xml, MANIFEST.MF) не нужны.
Конфигурация сервера
Самая большая проблема с сервером jboss 4.2.3.GA и файлом ejb.jar заключается в том, что он не работает по умолчанию! Описание проблемы и обходной путь вы можете найти здесь. (Это было самое сложное. На сервере Jboss 5.0 этой проблемы не существует, но в maven-cargo-plugin этот контейнер такой же экспериментальный)
Это все
Ниже я вставлю несколько ссылок на ссылки. Если у вас все еще будут проблемы, я отправлю вам весь свой исправленный проект.
Мой оригинальный ответ
Есть несколько проблем с Cargo и JBoss. Основная причина в том, что конфигурация источника данных в pom не работает, поэтому вам нужно развернуть отдельный файл источника данных. С точки зрения JBoss это должен быть файл, размещенный в главном каталоге развертывания (для Tomcat находится в папке META-INF). Вторая задача - скопировать библиотеку jdbc перед выполнением груза.
Большой ресурс для вас - это сообщение из блога Карлоса Санчеса. Может быть, вы можете использовать Selenium вместо JSFUnit тоже:)
Для копирования файла источника данных я использую следующую конфигурацию:
<plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-resources-plugin</artifactId> <executions> <execution> <id>copy-ds-context</id> <goals> <goal>copy-resources</goal> </goals> <phase>pre-integration-test</phase> <configuration> <outputDirectory>${jboss.deploy-ds.dir}</outputDirectory> <resources> <resource> <directory>${basedir}/src/main/webresources/META-INF</directory> <filtering>true</filtering> <includes> <include>context-ds.xml</include> </includes> </resource> </resources> </configuration> </execution> </executions> </plugin>