OpenEJB 4.5.1: Исключение NameNotFoundException

Я впервые использовал контейнерную систему OpenEJB. Когда я использую метод блокировки InitialContext, я получаю исключение NameNotFoundException. Я прочитал множество примеров и руководств, и в каждом примере метод поиска выглядит так:

initialContext.lookup("NameOfBean");

Теперь я нашел другое решение, которое использует поиск, подобный следующему фрагменту кода, который работает и для меня.

initialContext.lookup("java:global/classpath.ear/ProjectName/NameofBean");

Вопрос почему у меня не работает первая версия и что я сделал не так?

Выдержки из журнала OpenEJB:

INFO - ********************************************************************************
INFO - OpenEJB http://openejb.apache.org/
INFO - Startup: Sat Dec 22 13:17:59 CET 2012
INFO - Copyright 1999-2012 (C) Apache OpenEJB Project, All Rights Reserved.
INFO - Version: 4.5.1
INFO - Build date: 20121209
INFO - Build time: 08:47
INFO - ********************************************************************************
INFO - openejb.home = D:\workspace\ProjectName
INFO - openejb.base = D:\workspace\ProjectName
INFO - Succeeded in installing singleton service
INFO - Cannot find the configuration file [conf/openejb.xml].  Will attempt to create  one for the beans deployed.
INFO - Configuring Service(id=Default Security Service, type=SecurityService, provider-id=Default Security Service)
INFO - Configuring Service(id=Default Transaction Manager, type=TransactionManager, provider-id=Default Transaction Manager)
INFO - Using 'openejb.deployments.classpath.include=.*'
INFO - Found EjbModule in classpath: D:\workspace\ProjectName\build\classes
INFO - Searched 17 classpath urls in 2184 milliseconds.  Average 128 milliseconds per url.
INFO - Beginning load: D:\workspace\ProjectName\build\classes
INFO - Configuring enterprise application: D:\workspace\ProjectName\classpath.ear
WARNUNG - Method 'lookup' is not available for 'javax.annotation.Resource'. Probably using an older Runtime.
INFO - Auto-deploying ejb NameOfBean: EjbDeployment(deployment-id=NameOfBean)
[... AUTHORS'S NOTE: SOME MORE BEANS]
INFO - Assembling app: D:\workspace\ProjectName\classpath.ear
INFO - Hibernate Validator 4.2.0.Final
INFO - Ignoring XML configuration.
JAVA AGENT NOT INSTALLED. The JPA Persistence Provider requested installation of a ClassFileTransformer which requires a JavaAgent.  See http://openejb.apache.org/3.0/javaagent.html
INFO - OpenJPA dynamically loaded a validation provider.
INFO - Jndi(name=NameOfBeanRemote) --> Ejb(deployment-id=NameofBean)
INFO - Jndi(name=global/classpath.ear/ProjectName/NameOfBean!de.mypath.stateless.NameOfBeanInterface) --> Ejb(deployment-id=NameofBean)
INFO - Jndi(name=global/classpath.ear/ProjectName/NameofBean) --> Ejb(deployment-id=NameOfBean)
[... AUTHORS'S NOTE: SOME FOR OTHER BEANS]
INFO - OpenWebBeans Container is starting...
INFO - Adding OpenWebBeansPlugin : [CdiPlugin]
INFO - All injection points are validated successfully.
INFO - OpenWebBeans Container has started, it took 250 ms.
INFO - Created Ejb(deployment-id=NameOfBean, ejb-name=NameOfBean, container=Default Stateless Container)
[... AUTHORS'S NOTE: SOME FOR OTHER BEANS]
INFO - Quartz scheduler 'OpenEJB-TimerService-Scheduler' initialized from an externally provided properties instance.
INFO - Quartz scheduler version: 2.1.6
INFO - Scheduler OpenEJB-TimerService-Scheduler_$_OpenEJB started.
INFO - Started Ejb(deployment-id=NameOfBean, ejb-name=NameOfBean, container=Default Stateless Container)
[... AUTHORS'S NOTE: SOME FOR OTHER BEANS]

Это мой тестовый класс:

public class NamerOfBeanOpenEJBTest {

private static InitialContext initialContext;

@BeforeClass
public static void setUp() throws Exception {
       Properties properties = new Properties();
       properties.setProperty(Context.INITIAL_CONTEXT_FACTORY, "org.apache.openejb.client.LocalInitialContextFactory");
       properties.setProperty("openejb.deployments.classpath.include", ".*");
               initialContext = new InitialContext(properties);
}
@Test
public void testBean() throws NamingException{  
    Object object = initialContext.lookup("java:global/classpath.ear/ProjectName/NameOfBean");
    assertNotNull(object);
    assertTrue(object instanceof NameOfBean);
}

@AfterClass
public static void afterClass() throws Exception {
    if (initialContext != null) {
        initialContext.close();
    }}
}

У кого-нибудь есть советы или решения для меня? Большое спасибо.

Изменить:

В JBoss AS 7.1 поиск может выглядеть так:

new InitialContext().lookup("ejb:/ProjectName//NameOfBean!de." + "mypath.sessionbean.stateless.NameOfBeanInterface");

Разве это не возможно в OpenEJB? Должен ли я изменять каждый вызов поиска в каждом bean-компоненте, чтобы иметь локальный тест с OpenEJB? Это было бы не очень эффективно и экономило бы время.


person FredFloete    schedule 22.12.2012    source источник


Ответы (1)


Проблема решена!

Структура поиска: {deploymentId}{interfaceType.annotationName}. Поэтому в моем случае должно быть

initialContext.lookup("NameOfBeanLocal");

или initialContext.lookup("NameOfBeanRemote"); в зависимости от типа интерфейса.

Чтобы решить проблему с JBoss, вы можете переключиться с поиска по умолчанию

new InitialContext().lookup("ejb:/ProjectName//NameOfBean!de." + "mypath.sessionbean.stateless.NameOfBeanInterface");

на что-то более гибкое, например Dependcy-Lookup или Dependency-Injection, и используйте аннотацию @EJB. Оба способа поддерживаются JBoss и OpenEJB.

person FredFloete    schedule 28.12.2012