无法处理EJB类

时间:2016-04-29 10:40:47

标签: java maven-2 jboss-arquillian wildfly-10

在使用测试参数启动maven时,我得到了上面提到的异常。在创建集成测试部署时,我得到以下结果:

org.jboss.as.server.deployment.DeploymentUnitProcessingException: WFLYEJB0466: Failed to process business interfaces for EJB class class ..contract.ContractMockService

关注的课程如下:

package ..integration.bestand.contract;

import java.time.LocalDate;
import java.util.ArrayList;

import javax.ejb.Local;
import javax.ejb.Stateless;

import org.apache.deltaspike.core.api.exclude.Exclude;
import org.apache.deltaspike.core.api.projectstage.ProjectStage;

...

@Exclude(ifProjectStage = {
  ProjectStage.Production.class,
  ProjectStage.Staging.class,
  ..Integration.class,
  ..Qs.class,
  ..PatchQs.class
})
@Stateless
@Local(IContractIntService.class)
public class ContractMockService implements IContractIntService {

  ...

  return ContractBuilder.build();
  }

}

界面IContractIntService如下所示:

package ..integration.bestand.contract;

import javax.ejb.Local;

...

@Local
public interface IContractIntService {

  public enum State {
    SUCCESS,
    UNKNOWN_ERROR,
    NOT_FOUND;
    // TODO: Stati für Fehler hier definieren
  }

  //Interface comment
  Result<State, ContractDTO> retrieveContract(String contractIdentifier);
}

注意:界面位于另一个通过maven包含的项目中。

测试看起来像这样:

package ..api.contractregistration.service;

import static org.hamcrest.CoreMatchers.any;
import static org.hamcrest.MatcherAssert.assertThat;

import java.util.logging.Logger;

import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.jboss.shrinkwrap.api.asset.EmptyAsset;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.junit.Rule;
import org.junit.Test;
import org.junit.experimental.categories.Category;
import org.junit.rules.TestWatcher;
import org.junit.runner.RunWith;

import ..core.test.IntegrationTest;

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

  protected final Logger log = Logger.getLogger(ContractRegistrationIntegrationTest.class.getCanonicalName());

  @Rule
  public TestWatcher watcher = new TestWatcher() {

    @Override
    protected void starting(org.junit.runner.Description description) {
      log.info(String.format("---> Starting test: %s", description));
    }

    @Override
    protected void failed(Throwable e, org.junit.runner.Description description) {
      log.info(String.format("<--- Test failed: %s", description));
    }

    @Override
    protected void succeeded(org.junit.runner.Description description) {
      log.info(String.format("<--- Test succeeded: %s", description));
    }
  };

  @Deployment
  public static WebArchive createDeployment() {
    WebArchive result = ShrinkWrap.create(WebArchive.class)
        .addAsWebInfResource(EmptyAsset.INSTANCE, "beans.xml")
        .addAsResource("META-INF/persistence.xml", "META-INF/persistence.xml")
        .addPackages(true, "..ejb.portal")
        .addPackages(true, "..core")
        .deletePackages(true, "..core.config.deltaspike")
        .addPackages(true, "..integration")
        .addPackages(true, "..api")
        .addPackages(true, "org.apache.deltaspike.core")
        .addPackages(true, "..ejb.util");
    System.out.println("########## TEST DEPLOYMENT########" + result.toString(true));

    return result;
  }

  @Test
  public void test() {
    String tempPw = "bla"; // result.getDto();
    assertThat(tempPw, any(String.class));
  }

}

这个测试值得注意的是,我甚至没有在测试中使用任何MockService

maven配置如下所示:

目标:clean test -Parq-wildfly-managed JRE VM参数:-Djboss.home="myLocalWildflyDirectory"

JAVA_HOME设置为jdk8。

最后一件事是我的pom,特别是容器“arq-wildfly-managed”的一部分:

...

        <profile>
            <!-- An optional Arquillian testing profile that executes tests in your WildFly instance, e.g. for build server -->
            <!-- This profile will start a new WildFly instance, and execute the test, shutting it down when done -->
            <!-- Run with: mvn clean test -Parq-wildfly-managed -->
            <id>arq-wildfly-managed</id>
            <dependencies>
                <dependency>
                    <groupId>org.wildfly.arquillian</groupId>
                    <artifactId>wildfly-arquillian-container-managed</artifactId>
                    <scope>test</scope>
                </dependency>

                <dependency>
                    <groupId>de.ivi.torino</groupId>
                    <artifactId>torino-integration-bestand-mock-ejb</artifactId>
                    <version>1.0.0-SNAPSHOT</version>
                    <scope>test</scope>
                </dependency>

                <dependency>
                    <groupId>de.ivi.torino</groupId>
                    <artifactId>torino-integration-docservice-mock-ejb</artifactId>
                    <version>1.0.0-SNAPSHOT</version>
                    <scope>test</scope>
                </dependency>     
                <dependency>
                    <groupId>de.ivi.torino</groupId>
                    <artifactId>torino-integration-bestand-api</artifactId>
                    <version>1.0.0-SNAPSHOT</version>
                </dependency>         

            </dependencies>
        </profile>
...

使用clean verify package install(仅包含测试)的普通maven构建成功构建。

注意:对于这篇文章,我重命名了包以排除公司专业化。

类似的错误建议纠正ShrinkWrap部署,但我实际上包含了每个包,甚至尝试明确包含接口类。但仍然存在同样的错误。

是什么导致这种情况?

2 个答案:

答案 0 :(得分:0)

在Test(ShrinkWrap)中试试这个:

.addAsResource(new StringAsset("org.apache.deltaspike.ProjectStage=IntegrationTest"), "META-INF/apache-deltaspike.properties")

并将您的排除更改为:

@Exclude(exceptIfProjectStage = ProjectStage.IntegrationTest.class)

如果您需要排除其他阶段,请将其添加到此非常排除声明

答案 1 :(得分:0)

有点晚了,但问题的更好解决方案如下:

在ShrinkWrap部署中,需要使用shrinkwrap maven解析器。所以,而不是

.addPackages(true, "org.apache.deltaspike.core")

在创建result内部,使用maven解析器。应该看起来像这样:

ShrinkWrap
    .create(WebArchive.class, "test.war")
    .addAsLibraries(
        resolver.artifact("org.apache.deltaspike.core")
    .resolveAsFiles());

工件是maven artifactId。这将返回另一个.war。可以合并多个.wars(从解析器创建或在原始问题中看到的方式)。然后必须从部署方法返回此合并的.war。

背后的原因: 通过ShrinkWrap.create.*.addAsPackages..导入外部包含(在这种情况下为deltaspike)时缺少资源,因此这应仅用于内部项目包。要使用maven解析程序,可以在.pom文件中包含以下内容:

<dependency>
<groupId>org.jboss.shrinkwrap.resolver</groupId>
<artifactId>shrinkwrap-resolver-impl-maven</artifactId>
<scope>test</scope>
</dependency>
对于maven解析程序代码段,

归功于dzone.com。我目前正在处理另一个项目,所以我无法显示原始代码,但它与此非常相似。

也许这个解决方案将来会帮助某人。