![](/img/trans.png)
[英]how to run service with WildFly server by wildfly-maven-plugin?
[英]How to set up embedded WildFly server on the fly for testing with 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>
First 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中进行这些集成测试 ,我们使用Arquillian来运行集成测试。 查看src / test / resources / arquillian.xml ,我们指向一些特定的服务器配置文件而不是standalone.xml 。
此POM还显示了如何使用Maven依赖插件下载WildFly并在运行测试之前将其解压缩。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.