2

我的单元测试配置是:JUnit、DBUnit、Spring。

在我的 Spring 上下文中,我有一个嵌入式数据库 -

<jdbc:embedded-database id="dataSourceSpied">
    <jdbc:script location="classpath:test_ddl.sql"/>
</jdbc:embedded-database>

我的单元测试带有以下类级注释:

@ContextConfiguration(locations = "classpath:/test-context.xml")
@RunWith(SpringJUnit4ClassRunner.class)
@Transactional
@TestExecutionListeners({DependencyInjectionTestExecutionListener.class,
        TransactionDbUnitTestExecutionListener.class,
        DbUnitTestExecutionListener.class})

我的测试架构有以下片段:

CREATE TABLE test(
  id  BIGINT GENERATED BY DEFAULT AS IDENTITY,
  name  VARCHAR(255) NOT NULL,
  ...
);

@Transactional注释回滚我在单个单元测试方法中所做的任何更改,但不会清除id值!自动生成的id值不会重置,因此单元测试依赖于它们的运行顺序!

如何在测试期间重置 Spring 中自动生成的 HSQLDB 数据库字段?


也许trucate命令会有所帮助?

4

1 回答 1

0

在您的示例中,可以修改自动生成的 IDENTITY。

 ALTER TABLE test ALTER COLUMN id RESTART WITH 0

请参阅指南:

http://www.hsqldb.org/doc/2.0/guide/databaseobjects-chapt.html#dbc_table_manupulation

于 2013-04-09T14:53:37.303 回答