Skip to content

Commit ab88ff3

Browse files
committed
Merge branch '5.3.x'
2 parents 86387db + 51d263b commit ab88ff3

File tree

1 file changed

+16
-23
lines changed

1 file changed

+16
-23
lines changed

spring-jdbc/src/test/java/org/springframework/jdbc/support/incrementer/H2SequenceMaxValueIncrementerTests.java

+16-23
Original file line numberDiff line numberDiff line change
@@ -20,18 +20,16 @@
2020

2121
import javax.sql.DataSource;
2222

23+
import org.h2.engine.Mode.ModeEnum;
2324
import org.junit.jupiter.api.Test;
2425
import org.junit.jupiter.params.ParameterizedTest;
25-
import org.junit.jupiter.params.provider.ValueSource;
26+
import org.junit.jupiter.params.provider.EnumSource;
2627

2728
import org.springframework.jdbc.core.JdbcTemplate;
28-
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
2929
import org.springframework.jdbc.datasource.SimpleDriverDataSource;
3030
import org.springframework.jdbc.datasource.embedded.EmbeddedDatabase;
3131
import org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseBuilder;
3232
import org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseType;
33-
import org.springframework.transaction.PlatformTransactionManager;
34-
import org.springframework.transaction.support.TransactionTemplate;
3533

3634
import static org.assertj.core.api.Assertions.assertThat;
3735

@@ -60,12 +58,7 @@ void incrementsSequenceUsingH2EmbeddedDatabaseConfigurer() {
6058
.addScript("classpath:/org/springframework/jdbc/support/incrementer/schema.sql")
6159
.build();
6260

63-
JdbcTemplate jdbcTemplate = new JdbcTemplate(database);
64-
assertThat(jdbcTemplate.queryForObject("values next value for SEQ", int.class)).isEqualTo(1);
65-
66-
H2SequenceMaxValueIncrementer incrementer = new H2SequenceMaxValueIncrementer(database, "SEQ");
67-
assertThat(incrementer.nextIntValue()).isEqualTo(2);
68-
assertThat(incrementer.nextStringValue()).isEqualTo("3");
61+
assertIncrements(database);
6962

7063
database.shutdown();
7164
}
@@ -74,24 +67,24 @@ void incrementsSequenceUsingH2EmbeddedDatabaseConfigurer() {
7467
* Tests that the incrementer works when using all supported H2 <em>compatibility modes</em>.
7568
*/
7669
@ParameterizedTest
77-
@ValueSource(strings = { "STRICT", "LEGACY", "DB2", "Derby", "HSQLDB", "MariaDB", "MSSQLServer", "MySQL", "Oracle", "PostgreSQL" })
78-
void incrementsSequenceWithExplicitH2CompatibilityMode(String compatibilityMode) {
79-
String connectionUrl = String.format("jdbc:h2:mem:%s;MODE=%s", UUID.randomUUID().toString(), compatibilityMode);
70+
@EnumSource(ModeEnum.class)
71+
void incrementsSequenceWithExplicitH2CompatibilityMode(ModeEnum mode) {
72+
String connectionUrl = String.format("jdbc:h2:mem:%s;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=false;MODE=%s", UUID.randomUUID().toString(), mode);
8073
DataSource dataSource = new SimpleDriverDataSource(new org.h2.Driver(), connectionUrl, "sa", "");
8174
JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);
82-
PlatformTransactionManager transactionManager = new DataSourceTransactionManager(dataSource);
83-
TransactionTemplate transactionTemplate = new TransactionTemplate(transactionManager);
75+
jdbcTemplate.execute("CREATE SEQUENCE SEQ");
8476

85-
transactionTemplate.executeWithoutResult(status -> {
86-
jdbcTemplate.execute("CREATE SEQUENCE SEQ");
87-
assertThat(jdbcTemplate.queryForObject("values next value for SEQ", int.class)).isEqualTo(1);
88-
89-
H2SequenceMaxValueIncrementer incrementer = new H2SequenceMaxValueIncrementer(dataSource, "SEQ");
90-
assertThat(incrementer.nextIntValue()).isEqualTo(2);
91-
assertThat(incrementer.nextStringValue()).isEqualTo("3");
92-
});
77+
assertIncrements(dataSource);
9378

9479
jdbcTemplate.execute("SHUTDOWN");
9580
}
9681

82+
private void assertIncrements(DataSource dataSource) {
83+
assertThat(new JdbcTemplate(dataSource).queryForObject("values next value for SEQ", int.class)).isEqualTo(1);
84+
85+
H2SequenceMaxValueIncrementer incrementer = new H2SequenceMaxValueIncrementer(dataSource, "SEQ");
86+
assertThat(incrementer.nextIntValue()).isEqualTo(2);
87+
assertThat(incrementer.nextStringValue()).isEqualTo("3");
88+
}
89+
9790
}

0 commit comments

Comments
 (0)