3

我想根据所选的 Maven 配置文件使用两个不同的数据库。对于“生产”配置文件,我想使用 MySQL 数据库,而对于“开发”配置文件,我想使用内存中的 HSQLDB。

我发现可以有两个 persistence.xml 文件。一个在“src/main/resources/META-INF”中,另一个存储在“src/test/resources/META-INF”中。这使得选择不同的数据库进行测试成为可能。

但是是否也可以根据所选的 Maven 配置文件进行数据库选择?

4

1 回答 1

6

这是可能的,尽管不改变persistence.xml

我们为此使用 Maven 配置文件和资源过滤。您将需要persistence.xml在您的.properties文件或.pom.

在构建期间,您指定配置文件,maven 将用您的属性替换占位符。

我们已经使用这种技术在不同的部署环境之间切换数据源。您还可以使用它来切换 PU 或其他属性。

首先,为资源过滤定义配置文件:

<profiles>
  <profile>
   <id>set_datasource</id>
     <build>
       <!-- enable resource filter to set the datasource name -->
       <resources>
          <resource>
            <directory>src/main/resources</directory>
            <filtering>true</filtering>
      ...

为每个数据源创建一个配置文件:

<profile>
      <id>db_test</id>
    <properties>
      <database.name>test_ds</database.name>
    </properties>
</profile>

在您的持久性单元中,准备占位符

  <persistence-unit name="my_db">
    <jta-data-source>java:jboss/datasources/${datasource.name}</jta-data-source>
  </persistence-unit>

使用两个配置文件调用 maven:

mvn test -Pset_datasource,db_test

请注意,我们主要将其用于 UI 和用户测试。对于集成/功能测试,我们使用Arquillian。对于 Arquillian,您可以定义一个单独的persistence.xml文件,甚至可以即时创建一个。

于 2014-04-03T10:18:03.997 回答