我有一个应用程序,其中许多“单元”测试在执行期间使用与 Oracle 数据库的真实连接。
可以想象,执行这些测试需要花费太多时间,因为它们需要初始化一些 Spring 上下文,并与 Oracle 实例通信。除此之外,我们必须管理复杂的机制,例如事务,以避免在测试执行后修改数据库(即使我们使用类似 Spring 的有用类AbstractAnnotationAwareTransactionalTests
)。
所以我的想法是用内存数据库逐步替换这个 Oracle 测试实例。我会使用hsqldb
或者更好h2
。
我的问题是知道什么是最好的方法来做到这一点。我主要关心的是内存数据库结构的构建和参考数据的插入。
当然,我可以从 Oracle 中提取数据库结构,使用SQL Developer
or之类的工具TOAD
,然后修改这些脚本以使其适应hsqldb
orh2
语言。但我认为这不是更好的方法。
事实上,我已经在另一个项目中使用hsqldb
.,但我已经手动编写了所有脚本来创建表。幸运的是,我只需要创建几张表。在此步骤中,我的主要问题是将用于创建表的 Oracle 脚本“翻译”成该hsqldb
语言。
例如,使用以下 sql 命令在 Oracle 中创建的表:
CREATE TABLE FOOBAR (
SOME_ID NUMBER,
SOME_DATE DATE, -- Add primary key constraint
SOME_STATUS NUMBER,
SOME_FLAG NUMBER(1) DEFAULT 0 NOT NULL);
需要“翻译”为hsqldb
:
CREATE TABLE FOOBAR (
SOME_ID NUMERIC,
SOME_DATE TIMESTAMP PRIMARY KEY,
SOME_STATUS NUMERIC,
SOME_FLAG INTEGER DEFAULT 0 NOT NULL);
在我当前的项目中,有太多表无法手动执行...
所以我的问题:
- 你可以给我什么建议来实现这一目标?
- 是否提供
h2
或hsqldb
提供一些工具来从 Oracle 连接生成脚本?
技术信息
Java 1.6、Spring 2.5、Oracle 10.g、Maven 2
编辑
关于我的单元测试的一些信息:
在我使用的应用程序中hsqldb
,我进行了以下测试: - 一些与 DB 无关的“基本”单元测试。- 对于 DAO 测试,我曾经hsqldb
执行数据库操作,例如 CRUD。- 然后,在服务层,我曾经Mockito
模拟我的 DAO 对象,以便专注于服务测试而不是整个应用程序(即服务 + dao + DB)。
在我当前的应用程序中,我们遇到了最糟糕的情况:DAO 层测试需要运行 Oracle 连接。服务层不使用(还)任何模拟对象来模拟 DAO。因此服务测试也需要 Oracle 连接。
我知道模拟和内存数据库是两个不同的点,我会尽快解决它们。但是,我的第一步是尝试通过内存数据库删除 Oracle 连接,然后我将利用我的Mockito
知识来增强测试。
请注意,我还想将单元测试与集成测试分开。后者需要访问 Oracle 数据库,才能执行“真正的”测试,但我主要担心(这就是这个问题的目的)是我今天几乎所有的单元测试都不是孤立运行的。