嵌入式EJBContainer和JBoss 7.1.1.Final

嵌入式EJBContainer和JBoss 7.1.1.Final,jboss,junit,ejb,embeddable,Jboss,Junit,Ejb,Embeddable,有人能让EJBContainer.createEJBContainer()与JBoss 7.1.1.Final一起工作吗 作为JUnit测试运行以下代码会导致NullPointerException public class EJBContainerTest { private static EJBContainer ejbContainer; private static Context context; @BeforeClass public static void beforeClas

有人能让EJBContainer.createEJBContainer()与JBoss 7.1.1.Final一起工作吗

作为JUnit测试运行以下代码会导致NullPointerException

public class EJBContainerTest {

private static EJBContainer ejbContainer;
private static Context context;

@BeforeClass
public static void beforeClass() {
    System.setProperty("jboss.home", "/home/usr1/jboss-as-7.1.1.Final");
    ejbContainer = EJBContainer.createEJBContainer();
    context = ejbContainer.getContext();
}

@Test
public void test() {
    Assert.assertNotNull(context);
}
}

堆栈跟踪:

java.lang.NullPointerException
    at org.jboss.modules.Module.forClassLoader(Module.java:365)
    at org.jboss.modules.Module.forClassLoader(Module.java:365)
    at org.jboss.modules.Module.forClassLoader(Module.java:365)
    at org.jboss.modules.Module.getContextModuleLoader(Module.java:421)
    at org.jboss.as.embedded.ejb3.JBossStandaloneEJBContainerProvider.createEJBContainer(JBossStandaloneEJBContainerProvider.java:86)
    at javax.ejb.embeddable.EJBContainer.createEJBContainer(EJBContainer.java:93)
    at javax.ejb.embeddable.EJBContainer.createEJBContainer(EJBContainer.java:75)
    at org.arquillian.example.EJBContainerTest.beforeClass(EJBContainerTest.java:18)
    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:44)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:27)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
    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)
向上述代码中添加System.setProperty(“org.jboss.as.embedded.ejb3.barning”、“true”)可以修复NPE问题,嵌入式容器成功启动,但无法部署类,错误如下:

ERROR [org.jboss.msc.service.fail] (MSC service thread 1-2) MSC00001: Failed to start service jboss.deployment.unit.classes.STRUCTURE: org.jboss.msc.service.StartException in service jboss.deployment.unit.classes.STRUCTURE: Failed to process phase STRUCTURE of deployment "classes"
    at org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:119)
    at org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1811)
    at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1746)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) [rt.jar:1.6.0_26]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) [rt.jar:1.6.0_26]
    at java.lang.Thread.run(Thread.java:662) [rt.jar:1.6.0_26]
Caused by: org.jboss.as.server.deployment.DeploymentUnitProcessingException: Failed to mount deployment content
    at org.jboss.as.server.deployment.module.DeploymentRootMountProcessor.deploy(DeploymentRootMountProcessor.java:91)
    at org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:113)
    ... 5 more
Caused by: java.util.zip.ZipException: invalid CEN header (bad signature)
    at java.util.zip.ZipFile.open(Native Method) [rt.jar:1.6.0_26]
    at java.util.zip.ZipFile.<init>(ZipFile.java:127) [rt.jar:1.6.0_26]
    at java.util.jar.JarFile.<init>(JarFile.java:135) [rt.jar:1.6.0_26]
    at java.util.jar.JarFile.<init>(JarFile.java:99) [rt.jar:1.6.0_26]
    at org.jboss.vfs.spi.JavaZipFileSystem.<init>(JavaZipFileSystem.java:97)
    at org.jboss.vfs.spi.JavaZipFileSystem.<init>(JavaZipFileSystem.java:83)
    at org.jboss.vfs.VFS.mountZip(VFS.java:408)
    at org.jboss.vfs.VFS.mountZip(VFS.java:434)
    at org.jboss.as.server.deployment.DeploymentMountProvider$Factory$ServerDeploymentRepositoryImpl.mountDeploymentContent(DeploymentMountProvider.java:95)
    at org.jboss.as.server.deployment.module.DeploymentRootMountProcessor.deploy(DeploymentRootMountProcessor.java:87)
    ... 6 more

16:49:12,128 INFO  [org.jboss.as.server] (pool-9-thread-1) JBAS015870: Deploy of deployment "classes" was rolled back with failure message {"JBAS014671: Failed services" => {"jboss.deployment.unit.classes.STRUCTURE" => "org.jboss.msc.service.StartException in service jboss.deployment.unit.classes.STRUCTURE: Failed to process phase STRUCTURE of deployment \"classes\""}}
16:49:12,129 INFO  [org.jboss.as.controller] (pool-9-thread-1) JBAS014774: Service status report
JBAS014777:   Services which failed to start:      service jboss.deployment.unit.classes.STRUCTURE: org.jboss.msc.service.StartException in service jboss.deployment.unit.classes.STRUCTURE: Failed to process phase STRUCTURE of deployment "classes"
错误[org.jboss.msc.service.fail](msc服务线程1-2)MSC00001:无法启动服务jboss.deployment.unit.classes.STRUCTURE:org.jboss.msc.service.StartException in service jboss.deployment.unit.classes.STRUCTURE:无法处理部署“类”的阶段结构
位于org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:119)
位于org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1811)
位于org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1746)
位于java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)[rt.jar:1.6.026]
位于java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)[rt.jar:1.6.026]
在java.lang.Thread.run(Thread.java:662)[rt.jar:1.6.0_26]
原因:org.jboss.as.server.deployment.DeploymentUnitProcessingException:装载部署内容失败
位于org.jboss.as.server.deployment.module.DeploymentRootMountProcessor.deploy(DeploymentRootMountProcessor.java:91)
位于org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:113)
... 还有5个
原因:java.util.zip.ZipException:无效的CEN头(错误签名)
在java.util.zip.ZipFile.open(本机方法)[rt.jar:1.6.026]
在java.util.zip.ZipFile.(ZipFile.java:127)[rt.jar:1.6.0_26]
在java.util.jar.JarFile.(JarFile.java:135)[rt.jar:1.6.026]
在java.util.jar.JarFile.(JarFile.java:99)[rt.jar:1.6.0_26]
位于org.jboss.vfs.spi.JavaZipFileSystem.(JavaZipFileSystem.java:97)
位于org.jboss.vfs.spi.JavaZipFileSystem.(JavaZipFileSystem.java:83)
位于org.jboss.vfs.vfs.mountZip(vfs.java:408)
位于org.jboss.vfs.vfs.mountZip(vfs.java:434)
位于org.jboss.as.server.deployment.DeploymentMountProvider$Factory$ServerDeploymentRepositoryImpl.mountDeploymentContent(DeploymentMountProvider.java:95)
位于org.jboss.as.server.deployment.module.DeploymentRootMountProcessor.deploy(DeploymentRootMountProcessor.java:87)
... 还有6个
16:49:12128信息[org.jboss.as.server](池-9-thread-1)JBAS015870:部署“类”的部署已回滚,并显示失败消息{“JBAS014671:Failed services”=>{“jboss.deployment.unit.classes.STRUCTURE”=>服务jboss.deployment.unit.classes.STRUCTURE中的org.jboss.msc.service.StartException:无法处理部署\“classes\”}的阶段结构
16:49:12129信息[org.jboss.as.controller](池-9-thread-1)JBAS014774:服务状态报告
JBAS014777:无法启动的服务:服务jboss.deployment.unit.classes.STRUCTURE:org.jboss.msc.service.StartException in service jboss.deployment.unit.classes.STRUCTURE:无法处理部署“类”的阶段结构

您必须设置这些文件:default.persistence.properties、ejb3-interceptors-aop.xml、embedded-jboss-beans.xml、jboss-jms-beans.xml、jndi.properties、login-config.xml、security-beans.xml,如果您使用testNG,还可以在src/test/resources目录中添加testNG.xml

在课堂上,您必须添加:

System.setProperty("org.jboss.as.embedded.ejb3.BARREN", "true");  
System.setProperty("jboss.home", "/home/usr1/jboss-as-7.1.1.Final");  
System.setProperty("jboss.home.dir", "/home/usr1/jboss-as-7.1.1.Final");

JBoss类org.JBoss.vfs.VirtualJarFileInputStream中有一个旧bug。 它无法写入Zip文件的有效本地文件头。因此,创建临时Zip文件的类的部署在JBoss中无法工作