io.apicurio.registry.utils.tests.PostgreSqlEmbeddedTestResource Maven / Gradle / Ivy
package io.apicurio.registry.utils.tests;
import io.quarkus.test.common.QuarkusTestResourceLifecycleManager;
import io.zonky.test.db.postgres.embedded.EmbeddedPostgres;
import org.eclipse.microprofile.config.ConfigProvider;
import java.io.IOException;
import java.io.UncheckedIOException;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
public class PostgreSqlEmbeddedTestResource implements QuarkusTestResourceLifecycleManager {
private EmbeddedPostgres database;
/**
* @see QuarkusTestResourceLifecycleManager#start()
*/
@Override
public Map start() {
if (!Boolean.parseBoolean(System.getProperty("cluster.tests")) && isPostgresqlStorage()) {
String currentEnv = System.getenv("CURRENT_ENV");
if (currentEnv != null && "mas".equals(currentEnv)) {
Map props = new HashMap<>();
props.put("apicurio.storage.sql.kind", "postgresql");
props.put("apicurio.datasource.url", "jdbc:postgresql://localhost:5432/test");
props.put("apicurio.datasource.username", "test");
props.put("apicurio.datasource.password", "test");
return props;
} else {
return startPostgresql();
}
}
return Collections.emptyMap();
}
private static boolean isPostgresqlStorage() {
return ConfigProvider.getConfig().getValue("apicurio.storage.sql.kind", String.class)
.equals("postgresql");
}
private Map startPostgresql() {
try {
database = EmbeddedPostgres.start();
} catch (IOException e) {
throw new UncheckedIOException(e);
}
String datasourceUrl = database.getJdbcUrl("postgres", "postgres");
Map props = new HashMap<>();
props.put("apicurio.storage.sql.kind", "postgresql");
props.put("apicurio.datasource.url", datasourceUrl);
props.put("apicurio.datasource.username", "postgres");
props.put("apicurio.datasource.password", "postgres");
return props;
}
/**
* @see QuarkusTestResourceLifecycleManager#stop()
*/
@Override
public void stop() {
try {
if (database != null) {
database.close();
}
} catch (IOException e) {
throw new UncheckedIOException(e);
}
}
}