【问题标题】:Arquillian on WAS remote container and @PersistenceContextWAS 远程容器和 @PersistenceContext 上的 Arquillian
【发布时间】:2017-05-24 00:43:45
【问题描述】:

对于我们的集成测试,我想使用 Arquillian,并按照“入门 tutorial”中的所有步骤进行操作。由于我有一个现有的应用程序,因此设置起来并不是那么简单,但是我设法解决了大部分问题。现在我得到一个 NPE 异常,表明 CDI 不工作。根据WAS 8.5 remote container 文档,我意识到不支持@PersistenceContext。很不幸,从那以后我可能无法使用 Arquillian 或者还有其他可能性吗?

简化的代码结构:

class MyTest{ 

  @Deployment
  public static EnterpriseArchive createDeployment() {
  ...
  }

  @Inject
  public Service2Inject service;

  @Test
  public void testService() {
    //Assert.assertNotNull("Dependency injection failed!",service);
    String s = service.getSomeString("10");
    ...
  }
}


public class Service2Inject implements SomeInterface {

  @Inject
  private SomeOtherService serviceOther;

  @Override
  public String getSomeString(String id) {
    String testString = serviceOther.getSomeOtherStrings();
    ...
  }
}

public class SomeOtherService implements SomeInterface2 {

  @Inject
  private EntityManager entityManager;

  @Override
  public List<String> getSomeOtherStrings(String Id) {
    Query query = entityManager.createNamedQuery(...)
    ...
  }
}

public class EntityManagerProducer {
   @PersistenceContext(unitName="datasourcename")
   @Produces
   private EntityManager entityManager;
}

那么有没有可能用 Arquillian 和 WAS 远程容器测试我的应用程序?

更新:这是堆栈跟踪:

java.lang.NullPointerException
    at MyTest.testService(MyTest.java:84)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
    at java.lang.reflect.Method.invoke(Method.java:611)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
    at org.jboss.arquillian.junit.Arquillian$8$1.invoke(Arquillian.java:379)
    at org.jboss.arquillian.container.test.impl.execution.LocalTestExecuter.execute(LocalTestExecuter.java:60)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
    at java.lang.reflect.Method.invoke(Method.java:611)
    at org.jboss.arquillian.core.impl.ObserverImpl.invoke(ObserverImpl.java:96)
    at org.jboss.arquillian.core.impl.EventContextImpl.invokeObservers(EventContextImpl.java:99)
    at org.jboss.arquillian.core.impl.EventContextImpl.proceed(EventContextImpl.java:81)
    at org.jboss.arquillian.core.impl.ManagerImpl.fire(ManagerImpl.java:145)
    at org.jboss.arquillian.core.impl.ManagerImpl.fire(ManagerImpl.java:116)
    at org.jboss.arquillian.core.impl.EventImpl.fire(EventImpl.java:67)
    at org.jboss.arquillian.container.test.impl.client.protocol.local.LocalContainerMethodExecutor.invoke(LocalContainerMethodExecutor.java:50)
    at org.jboss.arquillian.container.test.impl.execution.RemoteTestExecuter.execute(RemoteTestExecuter.java:109)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
    at java.lang.reflect.Method.invoke(Method.java:611)
    at org.jboss.arquillian.core.impl.ObserverImpl.invoke(ObserverImpl.java:96)
    at org.jboss.arquillian.core.impl.EventContextImpl.invokeObservers(EventContextImpl.java:99)
    at org.jboss.arquillian.core.impl.EventContextImpl.proceed(EventContextImpl.java:81)
    at org.jboss.arquillian.core.impl.ManagerImpl.fire(ManagerImpl.java:145)
    at org.jboss.arquillian.core.impl.ManagerImpl.fire(ManagerImpl.java:116)
    at org.jboss.arquillian.core.impl.EventImpl.fire(EventImpl.java:67)
    at org.jboss.arquillian.container.test.impl.execution.ClientTestExecuter.execute(ClientTestExecuter.java:57)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
    at java.lang.reflect.Method.invoke(Method.java:611)
    at org.jboss.arquillian.core.impl.ObserverImpl.invoke(ObserverImpl.java:96)
    at org.jboss.arquillian.core.impl.EventContextImpl.invokeObservers(EventContextImpl.java:99)
    at org.jboss.arquillian.core.impl.EventContextImpl.proceed(EventContextImpl.java:81)
    at org.jboss.arquillian.container.test.impl.client.ContainerEventController.createContext(ContainerEventController.java:142)
    at org.jboss.arquillian.container.test.impl.client.ContainerEventController.createTestContext(ContainerEventController.java:129)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
    at java.lang.reflect.Method.invoke(Method.java:611)
    at org.jboss.arquillian.core.impl.ObserverImpl.invoke(ObserverImpl.java:96)
    at org.jboss.arquillian.core.impl.EventContextImpl.proceed(EventContextImpl.java:88)
    at org.jboss.arquillian.test.impl.TestContextHandler.createTestContext(TestContextHandler.java:130)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
    at java.lang.reflect.Method.invoke(Method.java:611)
    at org.jboss.arquillian.core.impl.ObserverImpl.invoke(ObserverImpl.java:96)
    at org.jboss.arquillian.core.impl.EventContextImpl.proceed(EventContextImpl.java:88)
    at org.jboss.arquillian.test.impl.TestContextHandler.createClassContext(TestContextHandler.java:92)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
    at java.lang.reflect.Method.invoke(Method.java:611)
    at org.jboss.arquillian.core.impl.ObserverImpl.invoke(ObserverImpl.java:96)
    at org.jboss.arquillian.core.impl.EventContextImpl.proceed(EventContextImpl.java:88)
    at org.jboss.arquillian.test.impl.TestContextHandler.createSuiteContext(TestContextHandler.java:73)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:60)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:37)
    at java.lang.reflect.Method.invoke(Method.java:611)
    at org.jboss.arquillian.core.impl.ObserverImpl.invoke(ObserverImpl.java:96)
    at org.jboss.arquillian.core.impl.EventContextImpl.proceed(EventContextImpl.java:88)
    at org.jboss.arquillian.core.impl.ManagerImpl.fire(ManagerImpl.java:145)
    at org.jboss.arquillian.test.impl.EventTestRunnerAdaptor.test(EventTestRunnerAdaptor.java:136)
    at org.jboss.arquillian.junit.Arquillian$8.evaluate(Arquillian.java:372)
    at org.jboss.arquillian.junit.Arquillian$4.evaluate(Arquillian.java:246)
    at org.jboss.arquillian.junit.Arquillian.multiExecute(Arquillian.java:431)
    at org.jboss.arquillian.junit.Arquillian.access$200(Arquillian.java:55)
    at org.jboss.arquillian.junit.Arquillian$5.evaluate(Arquillian.java:260)
    at org.jboss.arquillian.junit.Arquillian$7.evaluate(Arquillian.java:330)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
    at org.jboss.arquillian.junit.Arquillian$2.evaluate(Arquillian.java:205)
    at org.jboss.arquillian.junit.Arquillian.multiExecute(Arquillian.java:431)
    at org.jboss.arquillian.junit.Arquillian.access$200(Arquillian.java:55)
    at org.jboss.arquillian.junit.Arquillian$3.evaluate(Arquillian.java:219)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
    at org.jboss.arquillian.junit.Arquillian.run(Arquillian.java:167)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)

更新

由于我无法使用简单的 JarArchive 进行测试,因此我使用以下方法创建了一个像这样的收缩包装企业:

@Deployment
public static EnterpriseArchive createDeployment() {
  EnterpriseArchive ear = ShrinkWrap.create(EnterpriseArchive.class, "application-ear.ear")
  .as(ZipImporter.class)
  .importFrom(new File("../application-ear/target/application-ear-1.0-SNAPSHOT.ear"))
  .as(EnterpriseArchive.class);

  //now add the testClass and any test util classes that are not in the archive
  JavaArchive testLibraryHelper = ShrinkWrap.create(JavaArchive.class)
  .addClass(testClass)
  .addPackage(MiscUtil.class.getPackage())
  .addPackage(some.other.UtilClass.class.getPackage())
  //now for CDI working in testLibraryHelper
  .addAsManifestResource(EmptyAsset.INSTANCE, "beans.xml");
  ear.addAsLibrary(testLibraryHelper);
  return ear;
}

【问题讨论】:

  • 您是在尝试使用 WebSphere App Server 传统版还是 WebSphere Liberty?
  • 你能分享堆栈跟踪吗?我相信注入不直接支持测试,但不在您的应用程序中 - 只要您的容器支持注入它(我相信 WAS 就是这种情况),这应该可以工作。
  • @Scott Kurz:WebSphere App Server 传统
  • @bartosz.majsak 我添加了堆栈跟踪。基本上在访问注入的服务时,会抛出 NPE,因为它为空。
  • 这太疯狂了。我不羡慕你...如果我是你,我会尝试改变你创建 EnterpriseArchive 的方式并将.addAsLibrary() 替换为.addAsModule()。如果它不起作用,请尝试切换到WebArchive - 因为它似乎受到 arquillian 远程 WAS 适配器的支持。

标签: jakarta-ee integration-testing cdi jboss-arquillian


【解决方案1】:

一些线索:

  1. 确保您可以使用 CDI 成功运行最简单的测试(因此请删除 @PersistenceContext)并创建尽可能小的部署 - 因此请准备一个没有任何依赖关系的单个 CDI bean。
  2. 绝对确保部署的存档启用了 CDI。它必须包含beans.xml 文件。

如果您问我,我敢打赌,部署存档没有正确准备。这不是你的错,它一直是一项复杂而耗时的任务。

出于测试目的,请将存档类型更改为 JavaArchive 和 试试下面的 JUnit 示例:

@RunWith(Arquillian.class)
@Category(IntegrationTest.class)
public class AbcIT {

  @Deployment
  public static JavaArchive createDeployment() {
    JavaArchive jar = ShrinkWrap.create(JavaArchive.class)
            .addPackage("com.needed.package")
            .addClass("com.needed.class")
            .addAsManifestResource(EmptyAsset.INSTANCE, "beans.xml"); // CRUCIAL to make CDI work

    System.out.println(jar.toString(true)); // Print to see the content
    return jar;
  }

  @Inject
  private WhateverService service;

  // your test goes here...
}

稍后,如果上述方法可行,请继续使用 @PersistenceContext 并检查 arquillian-was-remote-8-container-adapter 现在是否支持它(因为您提到的文档是 2014 年的)。
如果我是你,我也会尝试询问 Arquillian 的社区。​​p>

希望对你有帮助。

【讨论】:

  • WAS 服务器不支持 JavaArchive 类型
  • 这怎么可能?你100%确定吗?这意味着无法将 ejb jar 部署到 WebSphere - 这听起来很荒谬。
  • 是的,就是这样。你得到的错误是:org.jboss.arquillian.container.spi.client.container.DeploymentException: Unsupported archive type has been provided for deployment: org.jboss.shrinkwrap.impl.base.spec.JavaArchiveImpl。这就是我在测试中使用EnterpriseArchive 文件的原因
  • 那太荒谬了。我鼓励您直接联系 Arquillian 的社区 here 或填写 arquillian 远程适配器的错误报告。
  • 我实际上已经这样做了,没有人证明我不是这样:developer.jboss.org/thread/273575 此外,我检查了实现的源代码,你可以自己看到只有 WebArchive 和 EnterpriseArchive(deploy 方法): github.com/arquillian/arquillian-container-was/blob/master/…
猜你喜欢
  • 1970-01-01
  • 2023-03-14
  • 1970-01-01
  • 1970-01-01
  • 2019-06-15
  • 2018-01-11
  • 1970-01-01
  • 2021-04-18
  • 2019-11-08
相关资源
最近更新 更多