2

我正在尝试使用 Jetty 访问本地 HSQL 数据库为我的 Spring Web 应用程序创建一些集成测试。目标:使用 Selenium(或类似的)运行测试,模拟/存根所有外部系统,并设置一个 HSQL 数据库来代替我们共享的 Oracle 数据库。测试是在 Maven 构建期间开始的(集成测试阶段)。该数据库由 Spring 的“jdbc:initialize-database”初始化,并在 Jetty 中注册为 JNDI 数据源。

经过几天尝试不同的配置,我终于到了创建、初始化数据库并注册为 Jetty 资源的地步,但是当测试用例运行时,它只是挂起;我认为是因为它正在等待数据库可用。

Maven配置

<plugin>
  <groupId>org.codehaus.cargo</groupId>
  <artifactId>cargo-maven2-plugin</artifactId>
  <version>1.3.3</version>
  <executions>
    <execution>
      <id>start</id>
      <phase>pre-integration-test</phase>
      <goals>
        <goal>start</goal>
      </goals>
    </execution>
    <execution>
      <id>stop</id>
      <phase>post-integration-test</phase>
      <goals>
        <goal>stop</goal>
      </goals>
    </execution>
  </executions>
  <configuration>
    <container>
      <containerId>jetty7x</containerId>
      <dependencies>
        <dependency>
          <groupId>org.hsqldb</groupId>
          <artifactId>hsqldb</artifactId>
        </dependency>
        <dependency>
          <groupId>c3p0</groupId>
          <artifactId>c3p0</artifactId>
        </dependency>
      </dependencies>
    </container>
    <configuration>
      <home>${project.build.directory}/cargo/configurations/jetty7x</home>
      <properties>
        <cargo.jetty.createContextXml>false</cargo.jetty.createContextXml>
        <cargo.datasource.datasource>
          cargo.datasource.url=jdbc:hsqldb:file:../../../myDB|
          cargo.datasource.driver=org.hsqldb.jdbcDriver|
          cargo.datasource.username=sa|
          cargo.datasource.password=|
          cargo.datasource.type=javax.sql.DataSource|
          cargo.datasource.jndi=jdbc/myDataSource
        </cargo.datasource.datasource>
      </properties>
    </configuration>
    <deployables>
      <deployable>
        <location>target/myApp</location>
        <properties>
          <context>myApp</context>
        </properties>
      </deployable>
    </deployables>
  </configuration>
 </plugin>

弹簧配置

<bean id="localDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
    <property name="driverClass" value="org.hsqldb.jdbcDriver"/>
    <property name="jdbcUrl" value="jdbc:hsqldb:file:target/myDB"/>
    <property name="user" value="sa"/>
    <property name="password" value=""/>
</bean>

 <jdbc:initialize-database data-source="mydataSource" ignore-failures="DROPS"> 
    <jdbc:script location="classpath:/sql-scripts/schema/create-schema.sql"/> 
    <jdbc:script location="classpath:/sql-scripts/schema/create-tables.sql"/> 
    <jdbc:script location="classpath:/sql-scripts/testdata/data-load.sql"/> 
</jdbc:initialize-database> 

我可能遗漏了一些东西,我试图通过许多其他帖子的建议来拼凑配置。任何帮助,将不胜感激。

4

1 回答 1

1

使用 HSQLDB 进行测试(尤其是复杂的测试设置)的推荐方法是运行服务器。

最初,您使用 shell 启动 HSQLDB 服务器,与您的测试设置无关。使用 Server 属性server.silent=false可以立即查看控制台上的连接和语句。

取得一些进展后,您可以自定义服务器设置。请参阅指南:

http://www.hsqldb.org/doc/2.0/guide/listeners-chapt.html

并总结了不同的测试选项:

http://www.hsqldb.org/doc/2.0/guide/deployment-chapt.html#dec_app_dev_testing

您可能需要使用 MVCC 事务模型。这减少了锁定并且有时避免了由于一个等待另一个提交而导致的连接挂起。

于 2013-03-30T23:10:39.600 回答