我有一个包含2个模块的应用程序:
Web JSF(部署在Tomcat上的WAR)
REST服务(部署在Wildfly上的WAR)
对于集成测试,我使用maven插件:
maven failsafe插件
fabric8 maven插件
我的测试源代码和资源位于两个应用程序src / integration-test / java。
中在集成测试阶段,fabric8构建Wildfly docker镜像,复制内置的articact(REST服务WAR),启动容器并运行测试。它工作正常。
但是......我想配置maven来部署2个应用程序( Web JSF WAR工件和REST服务WAR)并从JSF WAR / src / integration-test / java运行集成测试。 使用fabric8插件,它易于构建和运行Tomcat和Wildfly容器,但我无法找到如何从不同的maven模块部署2个不同的工件。 也许你有什么想法吗?
祝你好运, MJ。
答案 0 :(得分:1)
io.fabric8 docker-maven-plugin支持多个图像。您可以创建一个负责运行集成测试的模块。此模块将取决于您在问题中提到的2个WAR工件。
<dependencies>
<dependency>
<groupId>com.your.maven.group.here</groupId>
<artifactId>your-maven-artifact</artifactId>
<version>${project.version}</version>
<type>war</type>
</dependency>
<dependency>
...
</dependency>
</dependencies>
然后,您可以使用io.fabric8设置必要的容器。这是我的项目中的一个示例(为了简单和简洁的答案,一些细节正在删除)。这个例子不是关于Tomcat和Wildfly,而只是为了说明这个想法。
<plugin>
<groupId>io.fabric8</groupId>
<artifactId>docker-maven-plugin</artifactId>
<configuration>
<images>
<image>
....
</image>
<image>
<name>my-admin-site</name>
<alias>admin-ux</alias>
<build>
<from>jetty</from>
<ports>
<port>8080</port>
</ports>
<runCmds>
<run>mkdir -p /run/jetty /tmp/jetty</run>
<run>chmod -R 1777 /tmp</run>
<run>chown -R jetty:jetty /var/lib/jetty /run/jetty /tmp/jetty</run>
</runCmds>
<assembly>
<mode>dir</mode>
<basedir>/var/lib/jetty</basedir>
<inline xsi:schemaLocation="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.2">
<id>my-admin-ux</id>
<dependencySets>
<dependencySet>
<includes>
<include>com.your.maven.group.here:your-maven-artifact:war</include>
</includes>
<outputDirectory>./webapps</outputDirectory>
<outputFileNameMapping>myAdminSite.war</outputFileNameMapping>
</dependencySet>
</dependencySets>
<files>
<file>
<source>src/main/docker/admin-ux/resources/service.properties</source>
<outputDirectory>./resources</outputDirectory>
</file>
</files>
</inline>
<user>jetty:jetty</user>
</assembly>
</build>
<run>
<ports>
<port>10540:8080</port>
</ports>
<links>
<link>zookeeper:zookeeper</link>
</links>
</run>
</image>
<image>
.....
</image>
</images>
</configuration>
</plugin>