6

我有一组由 Spring Roo 为我的域对象(和 DAO ITD)生成的集成测试。

它们似乎被固定为使用“生产”applicationContext.xml,它读取 database.properties 并连接到我为试验项目而设置的 MySQL 数据库模式:

privileged aspect AdvertIntegrationTest_Roo_IntegrationTest {

    declare @type: AdvertIntegrationTest: @RunWith
        (SpringJUnit4ClassRunner.class);    

    declare @type: AdvertIntegrationTest: @ContextConfiguration
        (locations = "classpath:/META-INF/spring/applicationContext.xml");   

结果是我的演示数据库经常被这些测试填充垃圾。

我想更改配置,以便集成测试使用内存数据库,并单独保留 MySQL 数据库。目前,我能看到的唯一选择是删除 Roo 注释并从现在开始自己管理这些测试,但我现在更愿意让 Roo 保持循环。

是否可以配置我的项目,因此“mvn tomcat”和“mvn test”命令使用单独的数据库,而不会破坏 Spring Roo 设置?或者也许有更好的方法来解决我想做的事情?

4

3 回答 3

6

肖恩,

我一直在为同样的事情而苦苦挣扎。我最终将 applicationContext.xml 的副本放入 test/resources/META-INF/spring 并修改以下行:

<context:property-placeholder location="classpath*:META-INF/spring/test/*.properties"/>

在属性占位符指向的“测试”目录中,我放置了另一个配置 hsqldb 的 database.properties。

最后,我必须有一个配置 SQL 方言的 persistence.xml 的不同副本(也在 applicationContext.xml 中)

<bean class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" id="entityManagerFactory">
    <property name="persistenceXmlLocation" value="classpath:META-INF/persistence-for-tests.xml"/>
    <property name="dataSource" ref="dataSource"/>
</bean>

我想通过使用 pom.xml 魔法来获得更优雅的解决方案是可能的,但现在这对我来说似乎是一个可以接受的解决方案。

汉斯

于 2010-02-19T10:05:13.160 回答
1

肖恩,所有

我遇到了同样的问题,又发现了一件可能对所有人有用的东西。在 persistence.xml 中,可以定义多个具有不同名称的持久性单元,例如:

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

    <!-- production persistence unit -->
    <persistence-unit name="persistenceUnit" transaction-type="RESOURCE_LOCAL">
    ...
    </persistence-unit>
    <!-- test persistence unit -->
    <persistence-unit name="testPersistenceUnit" transaction-type="RESOURCE_LOCAL">
    ...
    </persistence-unit>
    </persistence>

然后在您的 applicationContext.xml (这个用于测试)中只需要 2 处更改:

  1. 属性文件从 META-INF/spring-test/* 加载

    <context:property-placeholder location="classpath*:META-INF/spring-test/*.properties"/>
    
  2. persistenceUnitName 指向persistance.xml 中的“testPersistenceUnit”

    <bean class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" id="entityManagerFactory">
    <property name="persistenceUnitName" value="testPersistenceUnit"/>
    <property name="dataSource" ref="dataSource"/>
    

希望这会对某人有所帮助,因为那里有很多答案,但是很难发现您可以在一个 persistence.xml 中定义多个persistenceUnits

席蒙

于 2012-03-13T00:32:15.703 回答
0

对我来说,这些步骤效果很好:

1)src/main/resources/META-INF/persistence.xml为您的测试目的添加一个新的持久性单元:

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.0" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
   <!-- Production Database -->
   <persistence-unit name="persistenceUnit" transaction-type="RESOURCE_LOCAL">
      <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
      <properties>
         <property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect" />
         <!-- value="create" to build a new database on each run; value="update" to modify an existing database; value="create-drop" means the same as "create" but also drops tables when Hibernate closes; value="validate" makes no changes to the database -->
         <property name="hibernate.hbm2ddl.auto" value="update" />
         <property name="hibernate.ejb.naming_strategy" value="org.hibernate.cfg.ImprovedNamingStrategy" />
         <property name="hibernate.connection.charSet" value="UTF-8" />
         <!-- Uncomment the following two properties for JBoss only -->
         <!-- property name="hibernate.validator.apply_to_ddl" value="false" /-->
         <!-- property name="hibernate.validator.autoregister_listeners" value="false" /-->
      </properties>
   </persistence-unit>

   <!-- Test Database -->
   <persistence-unit name="persistenceUnitTest" transaction-type="RESOURCE_LOCAL">
      <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
      <properties>
         <property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect" />
         <!-- value="create" to build a new database on each run; value="update" to modify an existing database; value="create-drop" means the same as "create" but also drops tables when Hibernate closes; value="validate" makes no changes to the database -->
         <property name="hibernate.hbm2ddl.auto" value="create" />
         <property name="hibernate.ejb.naming_strategy" value="org.hibernate.cfg.ImprovedNamingStrategy" />
         <property name="hibernate.connection.charSet" value="UTF-8" />
         <!-- Uncomment the following two properties for JBoss only -->
         <!-- property name="hibernate.validator.apply_to_ddl" value="false" /-->
         <!-- property name="hibernate.validator.autoregister_listeners" value="false" /-->
      </properties>
   </persistence-unit>
</persistence>

2)复制文件applicationContext.xmldatabase.propertiessrc/main/resources/META-INF/springsrc/test/resources/META-INF/spring(如果此文件夹不存在,则创建它)。

src/test/resources/META-INF/spring/database.properties3)像这样替换 in 的内容:

#Updated at Sat Sep 12 22:13:10 CEST 2015
#Sat Sep 12 22:13:10 CEST 2015
database.test.driverClassName=org.h2.Driver
database.test.url=jdbc:h2:./src/test/resources/db/data
database.test.username=sa
database.test.password=

4) 将文件src/test/resources/META-INF/spring/applicationContext.xmlapplicationContext.xmlto重命名testApplicationContext.xml并以类似的方式更改其内容(只需将 database.test 中的数据库引用和persistenceUnitName属性值从persistenceUnitto 更改persistenceUnitTest

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" xmlns:jee="http://www.springframework.org/schema/jee" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd         http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd         http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd         http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.2.xsd         http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd">
    <context:property-placeholder location="classpath*:META-INF/spring/*.properties"/>
    <context:spring-configured/>
    <context:component-scan base-package="com.jitter.finance.analyzer">
        <context:exclude-filter expression=".*_Roo_.*" type="regex"/>
        <context:exclude-filter expression="org.springframework.stereotype.Controller" type="annotation"/>
    </context:component-scan>
    <bean class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close" id="dataSource">
        <property name="driverClassName" value="${database.test.driverClassName}"/>
        <property name="url" value="${database.test.url}"/>
        <property name="username" value="${database.test.username}"/>
        <property name="password" value="${database.test.password}"/>
        <property name="testOnBorrow" value="true"/>
        <property name="testOnReturn" value="true"/>
        <property name="testWhileIdle" value="true"/>
        <property name="timeBetweenEvictionRunsMillis" value="1800000"/>
        <property name="numTestsPerEvictionRun" value="3"/>
        <property name="minEvictableIdleTimeMillis" value="1800000"/>
    </bean>
    <bean class="org.springframework.orm.jpa.JpaTransactionManager" id="transactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory"/>
    </bean>
    <tx:annotation-driven mode="aspectj" transaction-manager="transactionManager"/>
    <bean class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" id="entityManagerFactory">
        <property name="persistenceUnitName" value="persistenceUnitTest"/>
        <property name="dataSource" ref="dataSource"/>
    </bean>
</beans>

5)最后你可以像这样测试你的类:

import org.junit.Test;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.AbstractJUnit4SpringContextTests;

@ContextConfiguration(locations = {"classpath*:/META-INF/spring/testApplicationContext*.xml"})
public class QuoteListTest extends AbstractJUnit4SpringContextTests {
    @Test
    public void checkQuote(){
        /* some code to test, this will interact with the defined database.test */
    }
}
于 2015-10-10T20:53:44.720 回答