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