Playframework 2.2.x + Java +JPA - 单元测试和生产环境分离数据库

5

我正在使用Java + Playframework + JPA开发应用程序,使用的是PlayFramework 2.3-M1版本。

我想在运行应用程序时使用MySQL数据库,但是当我使用测试时:

activator test

我想使用内存数据库H2。

怎么做呢?

以下是我的

conf/META-INF/persistence.xml

<persistence xmlns="http://java.sun.com/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
             http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
             version="2.0">

    <persistence-unit name="prod" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <non-jta-data-source>prodDS</non-jta-data-source>
        <properties>
            <property name="hibernate.dialect" 
                      value="org.hibernate.dialect.MySQL5Dialect"/>
            <property name="hibernate.hbm2ddl.auto" value="update"/>
            <property name="hibernate.show_sql" value="true"></property>
            <property name="hibernate.format_sql" value="true"></property>
        </properties>
    </persistence-unit>

    <persistence-unit name="test" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <non-jta-data-source>TestDS</non-jta-data-source>
        <properties>
            <property name="hibernate.dialect" 
                      value="org.hibernate.dialect.H2Dialect"/>
            <property name="hibernate.hbm2ddl.auto" value="update"/>
            <property name="hibernate.show_sql" value="true"></property>
            <property name="hibernate.format_sql" value="true"></property>
        </properties>
    </persistence-unit>

</persistence>

conf/application.conf

# Database configuration
# ~~~~~ 
# You can declare as many datasources as you want.
# By convention, the default datasource is named `default`
#
db.test.driver=org.h2.Driver
db.test.url="jdbc:h2:mem:play"
db.test.user=sa
db.test.password=""

db.test.jndiName=TestDS

jpa.test=testPersistenceUnit

db.default.driver=com.mysql.jdbc.Driver
db.default.url="jdbc:mysql://X.X.X.X/lb"
db.default.user=lb
db.default.password="lb"

#
# You can expose this datasource via JNDI if needed (Useful for JPA)
db.default.jndiName=DefaultDS


jpa.default=defaultPersistenceUnit


# Evolutions
# ~~~~~
# You can disable evolutions if needed
evolutionplugin=disabled

# Ebean configuration
# ~~~~~
# You can declare as many Ebean servers as you want.
# By convention, the default server is named `default`
#
ebean.default="models.*"

这是完成任务的最佳方法吗?

谢谢

1个回答

11

所以我使用了一些混合/匹配方法来加快测试速度。

  1. 我为测试和生产使用了不同的配置文件
  2. 我在Prod和Testing中使用了两个不同的JPA持久性单元
  3. 在build.sbt中添加覆盖测试执行的配置文件
  4. 利用来生成测试模式
  5. 利用evolution将测试数据夹具加载到测试数据中

以下是我的文件:

conf/test.conf

db.default.driver=org.h2.Driver
db.default.url="jdbc:h2:mem:lb"
db.default.user=lb
db.default.password=""

#
# You can expose this datasource via JNDI if needed (Useful for JPA)
db.default.jndiName=DefaultDS


jpa.default=testPersistenceUnit


# Evolutions
# ~~~~~
# You can disable evolutions if needed
#evolutionplugin=disabled

conf/application.conf

db.default.driver=com.mysql.jdbc.Driver
db.default.url="jdbc:mysql://X.X.X.X/lb"
db.default.user=lb
db.default.password="lb"

#
# You can expose this datasource via JNDI if needed (Useful for JPA)
db.default.jndiName=DefaultDS

jpa.default=defaultPersistenceUnit

# Evolutions
# ~~~~~
# You can disable evolutions if needed
evolutionplugin=disabled
将以下选项添加到build.sbt文件中
build.sbt
javaOptions in Test += "-Dconfig.file=conf/test.conf"

最后是persistence.xml文件

<persistence xmlns="http://java.sun.com/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
             version="2.0">

    <!--Persistence Unit for Production-->

    <persistence-unit name="defaultPersistenceUnit" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <non-jta-data-source>DefaultDS</non-jta-data-source>
        <properties>
            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
            <property name="hibernate.hbm2ddl.auto" value="update"/>
            <property name="hibernate.show_sql" value="true"></property>
            <property name="hibernate.format_sql" value="true"></property>
        </properties>
    </persistence-unit>

    <!--Persistence Unit for Testing-->

    <persistence-unit name="testPersistenceUnit" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <non-jta-data-source>DefaultDS</non-jta-data-source>
        <properties>
            <property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect"/>
            <property name="hibernate.hbm2ddl.auto" value="update"/>
            <property name="hibernate.show_sql" value="false"></property>
            <property name="hibernate.format_sql" value="true"></property>
        </properties>
    </persistence-unit>
</persistence>

最后,我使用以下方式进行测试:

activator test
感谢play-framework谷歌组的用户提供了实现这一点的线索。

谢谢,我没有使用Hibernate,只用了Ebean,但是在全局test.conf中覆盖数据库是个好主意。顺便说一下,如果你使用-Dconfig.resource=test.conf,Play会自动查找conf/目录。 - Blacklight
@Blacklight 感谢您的反馈。是的,我同意,但由于很多东西都是从我的Jenkins构建脚本中复制过来的,需要完整路径才能部署到远程服务器,所以我就保持了这种方式。 - Reg Mem
1
谢谢。所有这些都应该是Play文档的一部分。 为测试和生产设置多个配置真的很困难。 - WarLord
你好,您能详细说明一下您是如何实施第四步和第五步的吗?谢谢! - Gus

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接