|
20 | 20 | import java.time.Duration; |
21 | 21 |
|
22 | 22 | import org.awaitility.Awaitility; |
23 | | -import org.junit.jupiter.api.Nested; |
24 | 23 | import org.junit.jupiter.api.Test; |
25 | 24 | import org.junit.jupiter.api.condition.OS; |
26 | 25 |
|
|
42 | 41 | */ |
43 | 42 | @DisabledOnOs(os = { OS.LINUX, OS.MAC }, architecture = "aarch64", |
44 | 43 | disabledReason = "The Oracle image has no ARM support") |
45 | | -class OracleJdbcDockerComposeConnectionDetailsFactoryIntegrationTests { |
| 44 | +class OracleJdbcDockerComposeConnectionDetailsFactoryIntegrationTests extends AbstractDockerComposeIntegrationTests { |
46 | 45 |
|
47 | | - @Nested |
48 | | - class OracleJdbcDockerComposeConnectionDetailsFactoryDefaultSettingsIntegrationTests extends AbstractDockerComposeIntegrationTests { |
49 | | - OracleJdbcDockerComposeConnectionDetailsFactoryDefaultSettingsIntegrationTests() { |
50 | | - super("oracle-compose.yaml", DockerImageNames.oracleXe()); |
51 | | - } |
52 | | - |
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 | | - } |
| 46 | + OracleJdbcDockerComposeConnectionDetailsFactoryIntegrationTests() { |
| 47 | + super("oracle-compose.yaml", DockerImageNames.oracleXe()); |
72 | 48 | } |
73 | 49 |
|
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 | | - } |
| 50 | + @Test |
| 51 | + @SuppressWarnings("unchecked") |
| 52 | + void runCreatesConnectionDetailsThatCanBeUsedToAccessDatabase() throws Exception { |
| 53 | + JdbcConnectionDetails connectionDetails = run(JdbcConnectionDetails.class); |
| 54 | + assertThat(connectionDetails.getUsername()).isEqualTo("app_user"); |
| 55 | + assertThat(connectionDetails.getPassword()).isEqualTo("app_user_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 | + }); |
99 | 68 | } |
| 69 | + |
100 | 70 | } |
0 commit comments