|
20 | 20 | import java.time.Duration;
|
21 | 21 |
|
22 | 22 | import org.awaitility.Awaitility;
|
| 23 | +import org.junit.jupiter.api.Nested; |
23 | 24 | import org.junit.jupiter.api.Test;
|
24 | 25 | import org.junit.jupiter.api.condition.OS;
|
25 | 26 |
|
|
41 | 42 | */
|
42 | 43 | @DisabledOnOs(os = { OS.LINUX, OS.MAC }, architecture = "aarch64",
|
43 | 44 | disabledReason = "The Oracle image has no ARM support")
|
44 |
| -class OracleJdbcDockerComposeConnectionDetailsFactoryIntegrationTests extends AbstractDockerComposeIntegrationTests { |
| 45 | +class OracleJdbcDockerComposeConnectionDetailsFactoryIntegrationTests { |
45 | 46 |
|
46 |
| - OracleJdbcDockerComposeConnectionDetailsFactoryIntegrationTests() { |
47 |
| - super("oracle-compose.yaml", DockerImageNames.oracleXe()); |
48 |
| - } |
| 47 | + @Nested |
| 48 | + class OracleJdbcDockerComposeConnectionDetailsFactoryDefaultSettingsIntegrationTests extends AbstractDockerComposeIntegrationTests { |
| 49 | + OracleJdbcDockerComposeConnectionDetailsFactoryDefaultSettingsIntegrationTests() { |
| 50 | + super("oracle-compose.yaml", DockerImageNames.oracleXe()); |
| 51 | + } |
49 | 52 |
|
50 |
| - @Test |
51 |
| - @SuppressWarnings("unchecked") |
52 |
| - void runCreatesConnectionDetailsThatCanBeUsedToAccessDatabase() throws Exception { |
53 |
| - JdbcConnectionDetails connectionDetails = run(JdbcConnectionDetails.class); |
54 |
| - assertThat(connectionDetails.getUsername()).isEqualTo("system"); |
55 |
| - assertThat(connectionDetails.getPassword()).isEqualTo("secret"); |
56 |
| - assertThat(connectionDetails.getJdbcUrl()).startsWith("jdbc:oracle:thin:@").endsWith("/xepdb1"); |
57 |
| - SimpleDriverDataSource dataSource = new SimpleDriverDataSource(); |
58 |
| - dataSource.setUrl(connectionDetails.getJdbcUrl()); |
59 |
| - dataSource.setUsername(connectionDetails.getUsername()); |
60 |
| - dataSource.setPassword(connectionDetails.getPassword()); |
61 |
| - dataSource.setDriverClass((Class<? extends Driver>) ClassUtils.forName(connectionDetails.getDriverClassName(), |
62 |
| - getClass().getClassLoader())); |
63 |
| - Awaitility.await().atMost(Duration.ofMinutes(1)).ignoreExceptions().untilAsserted(() -> { |
64 |
| - JdbcTemplate template = new JdbcTemplate(dataSource); |
65 |
| - assertThat(template.queryForObject(DatabaseDriver.ORACLE.getValidationQuery(), String.class)) |
66 |
| - .isEqualTo("Hello"); |
67 |
| - }); |
| 53 | + @Test |
| 54 | + @SuppressWarnings("unchecked") |
| 55 | + void runCreatesConnectionDetailsThatCanBeUsedToAccessDatabase() throws Exception { |
| 56 | + JdbcConnectionDetails connectionDetails = run(JdbcConnectionDetails.class); |
| 57 | + assertThat(connectionDetails.getUsername()).isEqualTo("system"); |
| 58 | + assertThat(connectionDetails.getPassword()).isEqualTo("secret"); |
| 59 | + assertThat(connectionDetails.getJdbcUrl()).startsWith("jdbc:oracle:thin:@").endsWith("/xepdb1"); |
| 60 | + SimpleDriverDataSource dataSource = new SimpleDriverDataSource(); |
| 61 | + dataSource.setUrl(connectionDetails.getJdbcUrl()); |
| 62 | + dataSource.setUsername(connectionDetails.getUsername()); |
| 63 | + dataSource.setPassword(connectionDetails.getPassword()); |
| 64 | + dataSource.setDriverClass((Class<? extends Driver>) ClassUtils.forName(connectionDetails.getDriverClassName(), |
| 65 | + getClass().getClassLoader())); |
| 66 | + Awaitility.await().atMost(Duration.ofMinutes(1)).ignoreExceptions().untilAsserted(() -> { |
| 67 | + JdbcTemplate template = new JdbcTemplate(dataSource); |
| 68 | + assertThat(template.queryForObject(DatabaseDriver.ORACLE.getValidationQuery(), String.class)) |
| 69 | + .isEqualTo("Hello"); |
| 70 | + }); |
| 71 | + } |
68 | 72 | }
|
69 | 73 |
|
| 74 | + @Nested |
| 75 | + class OracleJdbcDockerComposeConnectionDetailsFactoryNonDefaultSettingsIntegrationTests extends AbstractDockerComposeIntegrationTests { |
| 76 | + protected OracleJdbcDockerComposeConnectionDetailsFactoryNonDefaultSettingsIntegrationTests() { |
| 77 | + super("oracle-non-default-compose.yaml", DockerImageNames.oracleXe()); |
| 78 | + } |
| 79 | + |
| 80 | + @Test |
| 81 | + @SuppressWarnings("unchecked") |
| 82 | + void runCreatesConnectionDetailsWithNonDefaultUsernameAndPasswordThatCanBeUsedToAccessDatabase() throws Exception { |
| 83 | + JdbcConnectionDetails connectionDetails = run(JdbcConnectionDetails.class); |
| 84 | + assertThat(connectionDetails.getUsername()).isEqualTo("app_user"); |
| 85 | + assertThat(connectionDetails.getPassword()).isEqualTo("app_user_secret"); |
| 86 | + assertThat(connectionDetails.getJdbcUrl()).startsWith("jdbc:oracle:thin:@").endsWith("/xepdb1"); |
| 87 | + SimpleDriverDataSource dataSource = new SimpleDriverDataSource(); |
| 88 | + dataSource.setUrl(connectionDetails.getJdbcUrl()); |
| 89 | + dataSource.setUsername(connectionDetails.getUsername()); |
| 90 | + dataSource.setPassword(connectionDetails.getPassword()); |
| 91 | + dataSource.setDriverClass((Class<? extends Driver>) ClassUtils.forName(connectionDetails.getDriverClassName(), |
| 92 | + getClass().getClassLoader())); |
| 93 | + Awaitility.await().atMost(Duration.ofMinutes(1)).ignoreExceptions().untilAsserted(() -> { |
| 94 | + JdbcTemplate template = new JdbcTemplate(dataSource); |
| 95 | + assertThat(template.queryForObject(DatabaseDriver.ORACLE.getValidationQuery(), String.class)) |
| 96 | + .isEqualTo("Hello"); |
| 97 | + }); |
| 98 | + } |
| 99 | + } |
70 | 100 | }
|
0 commit comments