使用postgresql jdbc驱动程序和wildfly-arquillian-container-managed

时间:2018-02-01 13:58:15

标签: java postgresql wildfly jboss-arquillian

我们使用带有嵌入式wildfly [1]的arquillian来运行集成测试。到目前为止,我们在内存DB中使用了H2。由于某些原因,我们还需要在测试中切换到postgres以覆盖真实情况(在生产中,我们使用postgres)。 我在部署test.war时遇到此错误:

13:57:30,981 ERROR [org.jboss.as.controller.management-operation] (ServerService Thread Pool -- 33) WFLYCTL0013: Operation ("add") failed - address: ([
    ("subsystem" => "datasources"),
    ("jdbc-driver" => "postgresql")
]) - failure description: "WFLYJCA0041: Failed to load module for driver [org.postgresql.jdbc]"

这很清楚,因为驱动程序不可用。

但是如何使用嵌入式wildfly支持postgres jdbc驱动程序?我习惯将驱动程序复制到已安装的wildfly软件包的模块目录中...但是这里不可能......而且似乎没有我可以添加的maven依赖项,它添加了jdbc驱动程序...

顺便说一句,添加结尾,我的目标是使用一个改编的standalone.xml来定义数据源(而不是使用xxx-ds.xml文件),因为我也想设置其他设置。

[1]

    <dependency>
        <groupId>org.wildfly.arquillian</groupId>
        <artifactId>wildfly-arquillian-container-managed</artifactId>
    </dependency>

1 个答案:

答案 0 :(得分:1)

我设法解决了将standalone.xml,jdbc驱动程序和module.xml复制到提取的wildfly中的问题。

这是我使用maven和arquillian以及嵌入式野生蝇的第一步。欢迎任何改进建议。

<build>
    <plugins>
        ...
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-dependency-plugin</artifactId>
            <version>2.6</version>
            <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.1.0.Final</version>
                                <type>zip</type>
                                <overWrite>false</overWrite>
                                <outputDirectory>target</outputDirectory>
                            </artifactItem>
                        </artifactItems>
                    </configuration>
                </execution>                    
                <execution>
                    <id>copy-db-driver</id>
                    <phase>process-test-classes</phase>
                    <goals>
                        <goal>copy</goal> 
                   </goals>
                    <configuration>
                        <artifactItems>
                            <artifactItem>
                                <groupId>org.postgresql</groupId>
                                <artifactId>postgresql</artifactId>
                                <version>9.4.1212</version>
                                <outputDirectory>target/wildfly-10.1.0.Final/modules/system/layers/base/org/postgresql/main</outputDirectory>
                            </artifactItem>
                        </artifactItems>
                    </configuration>
                </execution>                    
            </executions>
        </plugin>            
        <plugin>
            <artifactId>maven-resources-plugin</artifactId>
            <version>3.0.2</version>
            <executions>
                <execution>
                    <id>copy-standalone-config</id>
                        <phase>process-test-classes</phase>
                        <goals>
                            <goal>copy-resources</goal>
                        </goals>
                        <configuration>
                            <outputDirectory>target/wildfly-10.1.0.Final/standalone/configuration</outputDirectory>
                            <resources>
                                <resource>
                                    <directory>src/test/resources</directory>
                                    <includes>
                                        <include>standalone.xml</include>
                                    </includes>
                                    <filtering>true</filtering>
                                </resource>
                            </resources>
                        </configuration>
                </execution>
                <execution>
                    <id>copy-module-xml</id>
                    <phase>process-test-classes</phase>
                    <goals>
                        <goal>copy-resources</goal>
                    </goals>
                    <configuration>
                        <outputDirectory>target/wildfly-10.1.0.Final/modules/system/layers/base/org/postgresql/main</outputDirectory>
                        <resources>
                            <resource>
                                <directory>src/test/resources</directory>
                                <includes>
                                    <include>module.xml</include>
                                </includes>
                            </resource>
                        </resources>
                    </configuration>
                </execution>
            </executions>
        </plugin>            
        ...
    </plugins>
</build>