java-如何动态设置嵌入式WildFly服务器以使用Maven进行测试

我有一个关于如何为集成测试即时设置嵌入式Wildfly 10服务器的问题.

<!-- Loading Wildfly 10 on the fly and copy it into the target folder. -->
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-dependency-plugin</artifactId>
    <executions>
        <execution>
            <id>unpack</id>
            <phase>process-test-classes</phase>
            <goals>
                <goal>unpack</goal>
            </goals>
            <configuration>
                <artifactItems>
                    <artifactItem>
                        <groupId>org.wildfly</groupId>
                        <artifactId>wildfly-dist</artifactId>
                        <version>10.0.0.Final</version>
                        <type>zip</type>
                        <overWrite>false</overWrite>
                        <outputDirectory>target</outputDirectory>
                    </artifactItem>
                </artifactItems>
            </configuration>
        </execution>
    </executions>
</plugin>

<plugin>
    <groupId>org.wildfly.plugins</groupId>
    <artifactId>wildfly-maven-plugin</artifactId>
    <version>1.1.0.Alpha1</version>
    <configuration>
        <jbossHome>target/wildfly-10.0.0.Final</jbossHome>
        <hostname>127.0.0.1</hostname>
        <!--  <port>9990</port> -->
        <filename>${project.build.finalName}.war</filename>
        <java-opts>
            <java-opt>-agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=5005</java-opt>
        </java-opts>
        <commands>
            <command>/subsystem=logging/file-handler=debug:add(level=DEBUG,autoflush=true,file={"relative-to"=>"jboss.server.log.dir",
                "path"=>"debug.log"})</command>
            <command>/subsystem=logging/logger=org.jboss.as:add(level=DEBUG,handlers=[debug])</command>
        </commands>
    </configuration>
    <dependencies>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.6.4</version>
        </dependency>
    </dependencies>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>deploy</goal>
            </goals>
        </execution>
        <execution>
            <id>start-wildfly</id>
            <phase>test-compile</phase>
            <goals>
                <goal>run</goal>
            </goals>
        </execution>
        <execution>
            <id>shutdown-wildfly</id>
            <phase>test</phase>
            <goals>
                <goal>shutdown</goal>
            </goals>
        </execution>
    </executions>
</plugin>

首先,Maven即时下载服务器,并将其保存到目标文件夹.稍后,我想复制一个新的standalone.xml,启动服务器,运行集成测试并停止服务器.

到目前为止,我还看不到我已经启动了服务器.

-------------------------------------------------------
 T E S T S
-------------------------------------------------------
Running com.example.FunctionalTest
Tests run: 1, Failures: 0, Errors: 1, Skipped: 0, Time elapsed: 0.071  sec <<< FAILURE! - in com.example.FunctionalTest
basicPingTest(com.example.FunctionalTest)  Time elapsed: 0.07 sec  <<< ERROR!
java.net.ConnectException: Connection refused
at com.example.FunctionalTest.basicPingTest(FunctionalTest.java:39)

Results :

Tests in error: 
 FunctionalTest.basicPingTest:39 » Connect Connection refused

Tests run: 1, Failures: 0, Errors: 1, Skipped: 0

有谁知道如何设置Maven来启动和停止嵌入式Wildfly服务器,启动测试用例并希望看到一些日志记录?

解决方法:

我建议看一下Arquillian,它将负责容器的生命周期管理,并通过将它们部署到容器来运行测试.令人高兴的是,这也允许从IDE内部运行测试,因为测试(运行程序)本身将管理容器的生命周期.

使用WildFly Maven插件控制容器时,应将Maven Failsafe插件用于这种集成测试,因为这样可以确保在执行测试后也可以在发生故障的情况下安全关闭容器.

您还可以从Hibernate Search中获取these integration tests,在这里我们使用Arquillian来运行集成测试.查看src / test / resources / arquillian.xml,在这里我们指向要使用的某些特定服务器配置文件,而不是standalone.xml.

该POM还显示了如何在运行测试之前使用Maven依赖插件下载WildFly并将其解压缩.

上一篇:使用现有MySQL数据库进行用户身份验证的Keycloak用户联合


下一篇:java-无法在Jboss EAP 7.0服务器中创建oracle数据源