2

我正在尝试(单元)测试我的 EJB 类,而不必启动我的 websphere 环境。现在我正在使用Open EJB,但是在为我的 EJB 中使用的其他 EJB 解析 JNDI 名称时存在一些问题......而且我现在无法从我的测试中注入模拟类。

获取 InitialContext

final Properties properties = new Properties();
properties.setProperty(Context.INITIAL_CONTEXT_FACTORY, "org.apache.openejb.client.LocalInitialContextFactory");
properties.setProperty("log4j.category.OpenEJB.options ", "debug");
properties.setProperty("log4j.category.OpenEJB.startup ", "debug");
properties.setProperty("log4j.category.OpenEJB.startup.config ", "debug");
properties.setProperty("MyOwnDatasource.JdbcDriver ", "com.ibm.as400.access.AS400JDBCDriver");
properties.setProperty("MyOwnDataSource.JdbcUrl ", "jdbc:as400:MYHOSTNAME;database name=MYDATABASE;libraries=MYDEFAULTTABLE");
ic = new InitialContext(properties);

在我的测试类中有一个查找java:comp/env/ejb/PrefixEjbNameLocalHome,我无法设置 Open EJB 以生成该格式的 JNDI 名称。

JNDI 名称格式的附加属性

我尝试像这样设置格式规则:

properties.setProperty("openejb.jndiname.format ", "comp/env/ejb/{interfaceClass}");

没有使用属性?

也不使用日志记录配置。我只看到来自 Open EJB 的INFOWARN消息,尽管我将log4j.category.OpenEJB.*之类设置为DEBUGTRACE

4

1 回答 1

3

弄乱您的测试用例的是“java:”部分。基本上 Context.INITIAL_CONTEXT_FACTORY 和 "java:" 是互斥的。InitialContext 类对“java:”或任何“foo:”查找有特殊的理解,如果它们位于名称的开头,它将不会使用您指定的 INITIAL_CONTEXT_FACTORY。JNDI 中有些令人沮丧的部分。

如果您查找与日志中打印的名称完全相同的名称,它将起作用。因此,例如此日志消息:

INFO - Jndi(name=WidgetBeanRemote) --> Ejb(deployment-id=WidgetBean)

然后在代码中:

Properties p = new Properties();
p.put(Context.INITIAL_CONTEXT_FACTORY, "org.apache.openejb.client.LocalInitialContextFactory");
// set any other properties you want
Context context = new InitialContext(p);

Object o = context.lookup("WidgetBeanRemote");
于 2010-05-19T19:12:04.990 回答