commit
579be1cea8
|
@ -39,8 +39,9 @@ import static org.assertj.core.api.Assertions.assertThat;
|
||||||
class PostgresJdbcDockerComposeConnectionDetailsFactoryIntegrationTests {
|
class PostgresJdbcDockerComposeConnectionDetailsFactoryIntegrationTests {
|
||||||
|
|
||||||
@DockerComposeTest(composeFile = "postgres-compose.yaml", image = TestImage.POSTGRESQL)
|
@DockerComposeTest(composeFile = "postgres-compose.yaml", image = TestImage.POSTGRESQL)
|
||||||
void runCreatesConnectionDetails(JdbcConnectionDetails connectionDetails) {
|
void runCreatesConnectionDetails(JdbcConnectionDetails connectionDetails) throws ClassNotFoundException {
|
||||||
assertConnectionDetails(connectionDetails);
|
assertConnectionDetails(connectionDetails);
|
||||||
|
checkDatabaseAccess(connectionDetails);
|
||||||
}
|
}
|
||||||
|
|
||||||
@DockerComposeTest(composeFile = "postgres-with-trust-host-auth-method-compose.yaml", image = TestImage.POSTGRESQL)
|
@DockerComposeTest(composeFile = "postgres-with-trust-host-auth-method-compose.yaml", image = TestImage.POSTGRESQL)
|
||||||
|
@ -53,8 +54,10 @@ class PostgresJdbcDockerComposeConnectionDetailsFactoryIntegrationTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@DockerComposeTest(composeFile = "postgres-bitnami-compose.yaml", image = TestImage.BITNAMI_POSTGRESQL)
|
@DockerComposeTest(composeFile = "postgres-bitnami-compose.yaml", image = TestImage.BITNAMI_POSTGRESQL)
|
||||||
void runWithBitnamiImageCreatesConnectionDetails(JdbcConnectionDetails connectionDetails) {
|
void runWithBitnamiImageCreatesConnectionDetails(JdbcConnectionDetails connectionDetails)
|
||||||
|
throws ClassNotFoundException {
|
||||||
assertConnectionDetails(connectionDetails);
|
assertConnectionDetails(connectionDetails);
|
||||||
|
checkDatabaseAccess(connectionDetails);
|
||||||
}
|
}
|
||||||
|
|
||||||
@DockerComposeTest(composeFile = "postgres-application-name-compose.yaml", image = TestImage.POSTGRESQL)
|
@DockerComposeTest(composeFile = "postgres-application-name-compose.yaml", image = TestImage.POSTGRESQL)
|
||||||
|
|
|
@ -43,6 +43,7 @@ class PostgresR2dbcDockerComposeConnectionDetailsFactoryIntegrationTests {
|
||||||
@DockerComposeTest(composeFile = "postgres-compose.yaml", image = TestImage.POSTGRESQL)
|
@DockerComposeTest(composeFile = "postgres-compose.yaml", image = TestImage.POSTGRESQL)
|
||||||
void runCreatesConnectionDetails(R2dbcConnectionDetails connectionDetails) {
|
void runCreatesConnectionDetails(R2dbcConnectionDetails connectionDetails) {
|
||||||
assertConnectionDetails(connectionDetails);
|
assertConnectionDetails(connectionDetails);
|
||||||
|
checkDatabaseAccess(connectionDetails);
|
||||||
}
|
}
|
||||||
|
|
||||||
@DockerComposeTest(composeFile = "postgres-with-trust-host-auth-method-compose.yaml", image = TestImage.POSTGRESQL)
|
@DockerComposeTest(composeFile = "postgres-with-trust-host-auth-method-compose.yaml", image = TestImage.POSTGRESQL)
|
||||||
|
@ -59,6 +60,7 @@ class PostgresR2dbcDockerComposeConnectionDetailsFactoryIntegrationTests {
|
||||||
@DockerComposeTest(composeFile = "postgres-bitnami-compose.yaml", image = TestImage.BITNAMI_POSTGRESQL)
|
@DockerComposeTest(composeFile = "postgres-bitnami-compose.yaml", image = TestImage.BITNAMI_POSTGRESQL)
|
||||||
void runWithBitnamiImageCreatesConnectionDetails(R2dbcConnectionDetails connectionDetails) {
|
void runWithBitnamiImageCreatesConnectionDetails(R2dbcConnectionDetails connectionDetails) {
|
||||||
assertConnectionDetails(connectionDetails);
|
assertConnectionDetails(connectionDetails);
|
||||||
|
checkDatabaseAccess(connectionDetails);
|
||||||
}
|
}
|
||||||
|
|
||||||
@DockerComposeTest(composeFile = "postgres-application-name-compose.yaml", image = TestImage.POSTGRESQL)
|
@DockerComposeTest(composeFile = "postgres-application-name-compose.yaml", image = TestImage.POSTGRESQL)
|
||||||
|
|
|
@ -4,6 +4,6 @@ services:
|
||||||
ports:
|
ports:
|
||||||
- '5432'
|
- '5432'
|
||||||
environment:
|
environment:
|
||||||
- 'POSTGRESQL_USER=myuser'
|
- 'POSTGRESQL_USERNAME=myuser'
|
||||||
- 'POSTGRESQL_DB=mydatabase'
|
- 'POSTGRESQL_DATABASE=mydatabase'
|
||||||
- 'POSTGRESQL_PASSWORD=secret'
|
- 'POSTGRESQL_PASSWORD=secret'
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2024 the original author or authors.
|
* Copyright 2012-2025 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -29,9 +29,18 @@ import org.springframework.util.StringUtils;
|
||||||
* @author Phillip Webb
|
* @author Phillip Webb
|
||||||
* @author Scott Frederick
|
* @author Scott Frederick
|
||||||
* @author Sidmar Theodoro
|
* @author Sidmar Theodoro
|
||||||
|
* @author He Zean
|
||||||
*/
|
*/
|
||||||
class PostgresEnvironment {
|
class PostgresEnvironment {
|
||||||
|
|
||||||
|
private static final String[] USERNAME_KEYS = new String[] { "POSTGRES_USER", "POSTGRESQL_USER",
|
||||||
|
"POSTGRESQL_USERNAME" };
|
||||||
|
|
||||||
|
private static final String DEFAULT_USERNAME = "postgres";
|
||||||
|
|
||||||
|
private static final String[] DATABASE_KEYS = new String[] { "POSTGRES_DB", "POSTGRESQL_DB",
|
||||||
|
"POSTGRESQL_DATABASE" };
|
||||||
|
|
||||||
private final String username;
|
private final String username;
|
||||||
|
|
||||||
private final String password;
|
private final String password;
|
||||||
|
@ -39,9 +48,18 @@ class PostgresEnvironment {
|
||||||
private final String database;
|
private final String database;
|
||||||
|
|
||||||
PostgresEnvironment(Map<String, String> env) {
|
PostgresEnvironment(Map<String, String> env) {
|
||||||
this.username = env.getOrDefault("POSTGRES_USER", env.getOrDefault("POSTGRESQL_USER", "postgres"));
|
this.username = extract(env, USERNAME_KEYS, DEFAULT_USERNAME);
|
||||||
this.password = extractPassword(env);
|
this.password = extractPassword(env);
|
||||||
this.database = env.getOrDefault("POSTGRES_DB", env.getOrDefault("POSTGRESQL_DB", this.username));
|
this.database = extract(env, DATABASE_KEYS, this.username);
|
||||||
|
}
|
||||||
|
|
||||||
|
private String extract(Map<String, String> env, String[] keys, String defaultValue) {
|
||||||
|
for (String key : keys) {
|
||||||
|
if (env.containsKey(key)) {
|
||||||
|
return env.get(key);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return defaultValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
private String extractPassword(Map<String, String> env) {
|
private String extractPassword(Map<String, String> env) {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2024 the original author or authors.
|
* Copyright 2012-2025 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -32,6 +32,7 @@ import static org.assertj.core.api.Assertions.assertThatIllegalStateException;
|
||||||
* @author Phillip Webb
|
* @author Phillip Webb
|
||||||
* @author Scott Frederick
|
* @author Scott Frederick
|
||||||
* @author Sidmar Theodoro
|
* @author Sidmar Theodoro
|
||||||
|
* @author He Zean
|
||||||
*/
|
*/
|
||||||
class PostgresEnvironmentTests {
|
class PostgresEnvironmentTests {
|
||||||
|
|
||||||
|
@ -67,6 +68,13 @@ class PostgresEnvironmentTests {
|
||||||
assertThat(environment.getUsername()).isEqualTo("me");
|
assertThat(environment.getUsername()).isEqualTo("me");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void getUsernameWhenHasPostgresqlUsername() {
|
||||||
|
PostgresEnvironment environment = new PostgresEnvironment(
|
||||||
|
Map.of("POSTGRESQL_USERNAME", "me", "POSTGRESQL_PASSWORD", "secret"));
|
||||||
|
assertThat(environment.getUsername()).isEqualTo("me");
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void getPasswordWhenHasPostgresPassword() {
|
void getPasswordWhenHasPostgresPassword() {
|
||||||
PostgresEnvironment environment = new PostgresEnvironment(Map.of("POSTGRES_PASSWORD", "secret"));
|
PostgresEnvironment environment = new PostgresEnvironment(Map.of("POSTGRES_PASSWORD", "secret"));
|
||||||
|
@ -111,6 +119,13 @@ class PostgresEnvironmentTests {
|
||||||
assertThat(environment.getDatabase()).isEqualTo("me");
|
assertThat(environment.getDatabase()).isEqualTo("me");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void getDatabaseWhenNoPostgresqlDatabaseAndPostgresqlUsername() {
|
||||||
|
PostgresEnvironment environment = new PostgresEnvironment(
|
||||||
|
Map.of("POSTGRESQL_USERNAME", "me", "POSTGRESQL_PASSWORD", "secret"));
|
||||||
|
assertThat(environment.getDatabase()).isEqualTo("me");
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void getDatabaseWhenHasPostgresDb() {
|
void getDatabaseWhenHasPostgresDb() {
|
||||||
PostgresEnvironment environment = new PostgresEnvironment(
|
PostgresEnvironment environment = new PostgresEnvironment(
|
||||||
|
@ -125,4 +140,11 @@ class PostgresEnvironmentTests {
|
||||||
assertThat(environment.getDatabase()).isEqualTo("db");
|
assertThat(environment.getDatabase()).isEqualTo("db");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void getDatabaseWhenHasPostgresqlDatabase() {
|
||||||
|
PostgresEnvironment environment = new PostgresEnvironment(
|
||||||
|
Map.of("POSTGRESQL_DATABASE", "db", "POSTGRESQL_PASSWORD", "secret"));
|
||||||
|
assertThat(environment.getDatabase()).isEqualTo("db");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue