170 похожих чатов

Всем привет, вопрос к тем, кто разбирается в транзацикциях на

уровне тестов, такой вопрос, у меня есть тест класс в котором три теста, в каждом происходит запись в базу и вычитка с базы (поднимается H2 in memory), весит @Transactional на уровне класса, тоесть чистятся записи после каждого метода, но автоинкремент не чистится, тоесть если 2 теста отработает , и почистятся, база будет пустая, но если в третем методе делать запись в базу, то у нее будет id = 3, ВОПРОС - как чистить автоинкремент после отрабатывания каждого теста?

1 ответов

10 просмотров

мы используем ALTER SEQUENCE TABLE_NAME RESTART WITH 1000 public class SequenceResetTestExecutionListener extends AbstractTestExecutionListener { private static final String STATEMENT_TEMPLATE = "ALTER SEQUENCE %s RESTART WITH 1000"; @Override public void beforeTestMethod(final TestContext testContext) { final JdbcTemplate jdbcTemplate = testContext.getApplicationContext().getBean(JdbcTemplate.class); final String[] resetStatements = jdbcTemplate.queryForList("SELECT * FROM INFORMATION_SCHEMA.SEQUENCES").stream() .map(sequence -> sequence.get("SEQUENCE_NAME")) .map(sequenceName -> String.format(STATEMENT_TEMPLATE, sequenceName)) .toArray(String[]::new); if (resetStatements.length > 0) { jdbcTemplate.batchUpdate(resetStatements); } } @Override public int getOrder() { return 0; } } и тогда перед каждым тестом сиквесны "сбрасываются

Похожие вопросы

Обсуждают сегодня

Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
48
Всем привет! Скажите, никто не пытался уменьшить размер процесса ssl, которые ассоциируется с открытым соединением (не помню точное название этого процесса, но там была какая-...
Алексей
20
а проверьте, собирается ли у кого сейчас транк лазаря через делюкс? у меня вот: fpcupdeluxe: info: Lazarus Native Installer (BuildModuleCustom: UserIDE): LazBuild: building Us...
Iluha Companets
20
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
Мне тут приспичило встроить в программу форматировние текста SQL, расставить переносы строк и отступы так, чтобы лучше читалось. Я что-то свое изобразил, оно после ключевых сл...
Sergey Bodrov
11
добрый день. возможно ли изменить цвет окон лазаруса? Как?
Budemposmotret
35
Господа, а кто-нибудь сталкивался с размещением на TTabControl/TTabSheet множества контролов (> 100) с последующими External: Access violation? Вот буквально на ровном месте. ...
Dmitry
29
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
Добрый день. Опять снова хочу обратиться к вам за помощью. После создания проэкта stack new, lazy.nvim + nvim-lspconfig/haskell-tools + hlint, ormolu из mason + hls из ghcup ...
Nannk
8
Does anyone have some zeroday's left?
Wito!d ♥️🩷
44
Карта сайта