【问题标题】:starting and stopping hsqldb from unit tests从单元测试中启动和停止 hsqldb
【发布时间】:2011-03-02 09:02:24
【问题描述】:

我正在尝试在内存模式下使用 hsqldb 创建集成测试。目前,我必须在运行单元测试之前从命令行启动 hsqldb 服务器。我希望能够从我的集成测试中控制 hsqldb 服务器。我似乎无法通过代码解决所有问题。

更新:

这似乎与在类路径中有一个 hibernate.cfg.xml 文件一起工作:

org.hsqldb.Server.main(new String[]{});

在我的 hibernate.cfg.xml 文件中:

<property name="connection.driver_class">org.hsqldb.jdbcDriver</property>
<property name="connection.url">jdbc:hsqldb:mem:ww</property>
<property name="connection.username">sa</property>
<property name="connection.password"></property>
<property name="connection.pool_size">1</property>
<property name="dialect">org.hibernate.dialect.HSQLDialect</property>
<property name="current_session_context_class">thread</property>
<property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
<property name="hbm2ddl.auto">update</property>

更新 似乎这只是在使用 jUnit 和内置测试运行器从 Eclipse 中运行单元测试时出现的问题。如果我运行

 mvn test

它们执行正确,没有例外。就依赖项而言,我是否遗漏了一些东西?我已经使用

生成了eclipse项目
mvn eclipse:eclipse

我的 pom 是:

<?xml version="1.0" encoding="UTF-8"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<modelVersion>4.0.0</modelVersion>

<groupId>com.myproject</groupId>
<artifactId>myproject</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>

<name>myproject</name>

<dependencies>
    <dependency>
        <groupId>jstl</groupId>
        <artifactId>jstl</artifactId>
        <version>1.1.2</version>
    </dependency>
    <dependency>
        <groupId>taglibs</groupId>
        <artifactId>standard</artifactId>
        <version>1.1.2</version>
    </dependency>

    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-core</artifactId>
        <version>3.3.2.GA</version>
    </dependency>
    <dependency>
        <groupId>com.oracle</groupId>
        <artifactId>ojdbc14</artifactId>
        <version>10.1.0.4.0</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.6.0</version>
    </dependency>

    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-simple</artifactId>
        <version>1.6.0</version>
    </dependency>
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.14</version>
    </dependency>
    <dependency>
        <groupId>javassist</groupId>
        <artifactId>javassist</artifactId>
        <version>3.8.0.GA</version>
    </dependency>
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-annotations</artifactId>
        <version>3.4.0.GA</version>
    </dependency>

    <!-- Test Dependencies -->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.8.1</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.easymock</groupId>
        <artifactId>easymock</artifactId>
        <version>3.0</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>hsqldb</groupId>
        <artifactId>hsqldb</artifactId>
        <version>1.8.0.1</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.mortbay.jetty</groupId>
        <artifactId>jetty-servlet-tester</artifactId>
        <version>6.1.24</version>
        <scope>test</scope>
    </dependency>


    <!-- Provided -->
    <dependency>
        <groupId>org.apache.tomcat</groupId>
        <artifactId>servlet-api</artifactId>
        <version>6.0.26</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.apache.tomcat</groupId>
        <artifactId>jsp-api</artifactId>
        <version>6.0.26</version>
    </dependency>

</dependencies>

<build>
    <finalName>ww_main</finalName>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <configuration>
                <source>1.6</source>
                <target>1.6</target>
            </configuration>
        </plugin>

        <plugin>
            <groupId>org.mortbay.jetty</groupId>
            <artifactId>maven-jetty-plugin</artifactId>
        </plugin>
    </plugins>
</build>
<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>

更新 好的,不确定这里到底出了什么问题,但我似乎已经修复了它。我删除了 HSQLDB 创建的所有文件,以及我的 Maven 目标文件夹中创建的所有文件,进行了清理,使用 maven 重新创建了我的 eclipse .project 并在 eclipse 中刷新了项目。我想我可能从以前的配置中遗留了一些东西,导致它被抛弃。

感谢大家的帮助!

【问题讨论】:

    标签: java unit-testing junit hsqldb


    【解决方案1】:

    我使用以下配置(直接受Hibernate tutorial启发)没有任何问题:

    <hibernate-configuration>
      <session-factory>
    
        <!-- Database connection settings -->
        <property name="hibernate.connection.driver_class" value="org.hsqldb.jdbcDriver"/>
        <property name="hibernate.connection.url" value="jdbc:hsqldb:mem:foobar"/>
        <property name="hibernate.connection.username" value="sa"/>
        <property name="hibernate.connection.password" value=""/>
    
        <!-- JDBC connection pool (use the built-in) -->
        <property name="connection.pool_size">1</property>
    
        <!-- SQL dialect -->
        <property name="hibernate.dialect" value="org.hibernate.dialect.HSQLDialect"/>
    
        <!-- Enable Hibernate's automatic session context management -->
        <property name="current_session_context_class">thread</property>
    
        <!-- Disable the second-level cache  -->
        <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
    
        <!-- Echo all executed SQL to stdout -->
        <property name="show_sql">true</property>
    
        <!-- Drop and re-create the database schema on startup -->
        <property name="hibernate.hbm2ddl.auto" value="update"/>
    
        <mapping resource="..."/>
    
      </session-factory>
    </hibernate-configuration>
    

    使用内存 HSQLDB 时,无需显式启动任何内容。只需使用mem: 协议,内存数据库将从 JDBC 启动。

    另见

    【讨论】:

    • 这正是我正在做的,但是当我运行单元测试时,我得到一个 java.sql.SQLException: socket creation 错误。我还收到一个 [main] WARN org.hibernate.cfg.SettingsFactory - 无法从休眠获取查询元数据的连接。
    • 我注意到它总是在我的类路径中创建文件,如果我使用的是基于文件的数据库而不是内存数据库,我希望创建这些文件。
    • 我给你答案是为了确认我的配置是正确的,这让我看看其他失败的原因。谢谢!
    • @Casey 很高兴它已解决,谢谢。我实际上正要回答:仔细检查你的配置,你一定在某个地方有冲突:)
    【解决方案2】:

    尝试将此附加到 jdbc url:

    ;ifexists=true;shutdown=true;
    

    【讨论】:

      【解决方案3】:

      在你的关机方法中做

      Statement st = conn.createStatement();
      st.execute("SHUTDOWN");
      conn.close();
      

      【讨论】:

        【解决方案4】:

        通过Runtime.getRuntime().exec("shell command here") 启动服务器呢?您只需为所有测试执行一次,因此不会增加太大的延迟。

        更新
        好吧,看来你自己解决了:)

        更新 2
        要在单元测试之前(或之后)执行一些代码,您可以

        static class TestWrapper extends TestSetup {
            TestWrapper(TestSuite suite) {
                super(suite);
            }
        
            protected void setUp() throws Exception {
                // start db
            }
        
            protected void tearDown() throws Exception {
                // kill db
            }
        }
        

        然后,只需将您的测试集包装在其中:new TestWrapper(suite)

        【讨论】:

        • 这还没有完全解决我不认为。我正在努力将它移到一个只执行一次的测试套件中,但它似乎有问题。不过,我还不能完全确定。
        • 已更新。我做了很多这样的事情,所以只需从我的项目中复制粘贴 :)
        【解决方案5】:

        也许这可能有助于在单元测试中以服务器模式启动 HSQL,但在同一个 JVM 中。 示例代码运行 org.hsqldb.server.WebServer(即端口 80),但您可以使用 org.hsqldb.server.Server。您可以在其中一个上调用 setPort 来覆盖默认端口。

        https://stackoverflow.com/a/37784679/15789

        【讨论】:

          【解决方案6】:

          检查我的 hsqldb maven 插件: https://github.com/avianey/hsqldb-maven-plugin

          您可以像 jetty-maven-plugin 或 tomee-maven-plugin 一样为您的测试启动/停止它:

          <plugin>
          
              <!-- current version -->
              <groupId>fr.avianey.mojo</groupId>
              <artifactId>hsqldb-maven-plugin</artifactId>
              <version>1.0.0</version>
          
              <!-- 
                  default value for in memory jdbc:hsqldb:hsql://localhost/xdb
                  override only values you want to change
              -->
              <configuration>
                  <driver>org.hsqldb.jdbcDriver</driver>
                  <path>mem:test</path>
                  <address>localhost</address>
                  <name>xdb</name>
                  <username>sa</username>
                  <password></password>
                  <validationQuery>SELECT 1 FROM INFORMATION_SCHEMA.SYSTEM_USERS</validationQuery>
              </configuration>
          
              <!-- call start and stop -->
              <executions>
                  <execution>
                      <id>start-hsqldb</id>
                      <phase>pre-integration-test</phase>
                      <goals>
                          <goal>start</goal>
                      </goals>
                  </execution>
                  <execution>
                      <id>stop-hsqldb</id>
                      <phase>post-integration-test</phase>
                      <goals>
                          <goal>stop</goal>
                      </goals>
                  </execution>
              </executions>
          
          </plugin>
          

          【讨论】:

            猜你喜欢
            • 2020-07-15
            • 1970-01-01
            • 2013-01-09
            • 2012-02-04
            • 2011-08-21
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 2011-04-22
            相关资源
            最近更新 更多