Где я могу найти полный пример плагина 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 находится в корневой папке EJB jar и содержит следующие строки:

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

Исходный код bean-компонента

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 = nulli--depency, false-depency = nulli--зависимый, false-зависимый / false-type = nulli--зависимый / false-зависимый / false-type = nulli--зависимый / false-зависимости name = EchoBean / remote, resolved-jndi-name = null, beanInterface = interface de.betabeans.EchoBeanRemote}, # web-app: AnnotatedEJBReferenceMetaData {name = NewServlet / newSessionBean, ejb-ref-type = null, link = null, ignore -dependencecy = false, mapped / 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


person mjn    schedule 10.11.2009    source источник
comment
В сети есть множество примеров Cargo + JBoss, например i-proving.ca/space/ Technologies / Maven / Maven + Recipes / или wineetmanohar. com / 2009/05/26 / maven-cargo-jboss. Но есть много способов использовать Cargo, так что, возможно, вам стоит вставить сюда свой pom и ошибку, чтобы мы могли помочь. В чем собственно проблема?   -  person Pascal Thivent    schedule 10.11.2009
comment
Я получаю это исключение: javax.naming.NoInitialContextException: невозможно создать экземпляр класса: org.jnp.interfaces.NamingContextFactory [Корневое исключение - java.lang.ClassNotFoundException: org.jnp.interfaces.NamingContextFactory]   -  person mjn    schedule 11.11.2009
comment
Это можно исправить, добавив jbossall-client.jar в POM, но я столкнусь с исключением classcast, если использую метод поиска контекста. У меня нет файла конфигурации jboss.xml, и теперь я пытаюсь настроить EJB там. Если я использую аннотацию @EJB, я получаю исключение нулевого указателя.   -  person mjn    schedule 11.11.2009
comment
Пожалуйста, отредактируйте свой вопрос с этими комментариями, система комментариев не идеальна для фрагментов кода. Также предоставьте код вашего поиска и настройки JNDI.   -  person Pascal Thivent    schedule 11.11.2009
comment
Вы запускаете этот тест как обычный тест jUnit или как грузовой? Можете ли вы разместить весь свой проект в Интернете (например, на code.google.com)?   -  person cetnar    schedule 14.11.2009
comment
Я запускаю mvn install, которая запускает плагин Cargo, при этом запускается JBoss 5.1, развертывается приложение, запускаются тесты и снова закрывается JBoss. Позже выложу проект.   -  person mjn    schedule 14.11.2009
comment
Загрузил полный проект Maven в mikejustin.com/download/JBossSimpleEJBApp-ejb-test. zip   -  person mjn    schedule 14.11.2009
comment
Я проверю это. Только одно: почему jndi.properties находится в корневой папке EJB jar? Вам нужно поместить его в путь к классам клиента, что означает здесь модульный тест (т.е. src/tests/resources).   -  person Pascal Thivent    schedule 14.11.2009
comment
Вы правы, но после исправления здесь тест все равно не проходит с той же ошибкой.   -  person mjn    schedule 14.11.2009
comment
Я нашел несколько отчетов о проблемах для UndeclaredThrowableException в JBoss, которые, похоже, указывают на то, что тест не использует правильную версию клиентских файлов jar. Я использовал 5.1.0.GA в POM, и это также установленная версия сервера. Сравнение всех файлов Jar займет некоторое время :)   -  person mjn    schedule 14.11.2009
comment
Я обновил свой ответ. Если у вас возникнут проблемы с применением моего патча, я пришлю вам все свои исходники. Я подготовил версию для Jboss 4.2.3.   -  person cetnar    schedule 15.11.2009


Ответы (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-plugin

Я переместил папку ресурсов в тестовую папку

Файл 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>
person cetnar    schedule 10.11.2009
comment
Большое спасибо за ваш ответ, который может быть полезен в будущем - в моем текущем очень простом проекте-примере нет задействованных источников данных. - person mjn; 12.11.2009
comment
Отлично работает - очень признателен за вашу помощь! - person mjn; 15.11.2009