10

我正在测试一个返回 json 响应的控制器,但测试在第一次后失败,因为 h2 数据库没有重置自动增量 ID。使用夹具或手动创建对象有同样的问题。

@Before
public void setUp() {
    Fixtures.deleteAllModels();
    Fixtures.loadModels("data.yaml");
}

如何解决这个问题呢?

4

3 回答 3

22

启动您的 play 应用程序,使用此 url 启动浏览器(如果您在本地运行 play 应用程序):

http://localhost:9000/@db

输入您的 h2 db,然后键入以下命令并运行:

ALTER TABLE <table_name> ALTER COLUMN <column_name> RESTART WITH 1

如果您想以编程方式执行此操作,Fixtures.executeSQL()可能会有用

有关更多信息,请查看http://www.h2database.com/html/grammar.html#alter_table_alter

于 2012-04-09T03:43:01.797 回答
3

如果您使用的是 Spring,我发现这篇博客文章建议使用@DirtiesContext(classMode = DirtiesContext.ClassMode.AFTER_EACH_TEST_METHOD)

这样每个测试都使用一个新的应用程序上下文,从而重置 db 增量。

于 2017-07-28T08:15:18.933 回答
2

在您的表上执行 SQL 脚本:

TRUNCATE TABLE my_table RESTART IDENTITY;
ALTER SEQUENCE my_table_id_seq RESTART WITH 1;

H2 应该是 1.4.200 或更高版本。

https://www.h2database.com/html/commands.html

于 2020-06-08T16:45:08.653 回答