public class org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration extends java.lang.Object implements org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.TestConnectionIntegration, org.finos.legend.engine.test.shared.framework.TestServerResource
{
public org.testcontainers.containers.PostgreSQLContainer postgreSQLContainer;
private org.finos.legend.engine.shared.core.vault.VaultImplementation vaultImplementation;
public void <init>()
{
org.testcontainers.utility.DockerImageName v, v;
org.testcontainers.containers.PostgreSQLContainer v;
org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.testcontainers.containers.PostgreSQLContainer;
v = staticinvoke <org.testcontainers.utility.DockerImageName: org.testcontainers.utility.DockerImageName parse(java.lang.String)>("postgres");
v = virtualinvoke v.<org.testcontainers.utility.DockerImageName: org.testcontainers.utility.DockerImageName withTag(java.lang.String)>("9.6.12");
specialinvoke v.<org.testcontainers.containers.PostgreSQLContainer: void <init>(org.testcontainers.utility.DockerImageName)>(v);
v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.testcontainers.containers.PostgreSQLContainer postgreSQLContainer> = v;
return;
}
public org.eclipse.collections.api.list.MutableList group()
{
java.lang.String[] v;
org.eclipse.collections.api.factory.list.MutableListFactory v;
org.eclipse.collections.api.list.MutableList v;
org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration;
v = <org.eclipse.collections.impl.factory.Lists: org.eclipse.collections.api.factory.list.MutableListFactory mutable>;
v = newarray (java.lang.String)[3];
v[0] = "Store";
v[1] = "Relational";
v[2] = "Postgres";
v = interfaceinvoke v.<org.eclipse.collections.api.factory.list.MutableListFactory: org.eclipse.collections.api.list.MutableList 'with'(java.lang.Object[])>(v);
return v;
}
public org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType getDatabaseType()
{
org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType v;
org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration;
v = <org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType: org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType Postgres>;
return v;
}
public void setup()
{
org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration;
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: void startPostgresContainer()>();
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: void registerVault()>();
return;
}
public org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.RelationalDatabaseConnection getConnection()
{
org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.StaticDatasourceSpecification v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType v, v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.authentication.UserNamePasswordAuthenticationStrategy v;
org.testcontainers.containers.PostgreSQLContainer v, v, v;
java.lang.Integer v, v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.RelationalDatabaseConnection v;
int v, v;
java.lang.String v;
org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration v;
boolean v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.testcontainers.containers.PostgreSQLContainer postgreSQLContainer>;
v = virtualinvoke v.<org.testcontainers.containers.PostgreSQLContainer: boolean isRunning()>();
if v != 0 goto label;
virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: void setup()>();
label:
v = new org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.StaticDatasourceSpecification;
specialinvoke v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.StaticDatasourceSpecification: void <init>()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.testcontainers.containers.PostgreSQLContainer postgreSQLContainer>;
v = virtualinvoke v.<org.testcontainers.containers.PostgreSQLContainer: java.lang.String getHost()>();
v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.StaticDatasourceSpecification: java.lang.String host> = v;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.testcontainers.containers.PostgreSQLContainer postgreSQLContainer>;
v = <org.testcontainers.containers.PostgreSQLContainer: java.lang.Integer POSTGRESQL_PORT>;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = virtualinvoke v.<org.testcontainers.containers.PostgreSQLContainer: java.lang.Integer getMappedPort(int)>(v);
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.StaticDatasourceSpecification: int port> = v;
v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.StaticDatasourceSpecification: java.lang.String databaseName> = "test";
v = new org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.authentication.UserNamePasswordAuthenticationStrategy;
specialinvoke v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.authentication.UserNamePasswordAuthenticationStrategy: void <init>()>();
v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.authentication.UserNamePasswordAuthenticationStrategy: java.lang.String baseVaultReference> = "postgresql.";
v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.authentication.UserNamePasswordAuthenticationStrategy: java.lang.String userNameVaultReference> = "user";
v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.authentication.UserNamePasswordAuthenticationStrategy: java.lang.String passwordVaultReference> = "password";
v = new org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.RelationalDatabaseConnection;
v = <org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType: org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType Postgres>;
specialinvoke v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.RelationalDatabaseConnection: void <init>(org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.specification.DatasourceSpecification,org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.authentication.AuthenticationStrategy,org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType)>(v, v, v);
v = <org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType: org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType Postgres>;
v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.RelationalDatabaseConnection: org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType type> = v;
v.<org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.RelationalDatabaseConnection: java.lang.String element> = null;
return v;
}
public void cleanup()
{
org.testcontainers.containers.PostgreSQLContainer v;
org.finos.legend.engine.shared.core.vault.VaultImplementation v;
org.finos.legend.engine.shared.core.vault.Vault v;
org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration;
v = <org.finos.legend.engine.shared.core.vault.Vault: org.finos.legend.engine.shared.core.vault.Vault INSTANCE>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.finos.legend.engine.shared.core.vault.VaultImplementation vaultImplementation>;
virtualinvoke v.<org.finos.legend.engine.shared.core.vault.Vault: void unregisterImplementation(org.finos.legend.engine.shared.core.vault.VaultImplementation)>(v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.testcontainers.containers.PostgreSQLContainer postgreSQLContainer>;
virtualinvoke v.<org.testcontainers.containers.PostgreSQLContainer: void stop()>();
return;
}
private void startPostgresContainer()
{
long v, v, v;
org.testcontainers.containers.PostgreSQLContainer v, v, v, v;
java.lang.Integer v, v;
int v, v;
java.lang.String v, v;
java.io.PrintStream v, v;
org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration;
v = <java.lang.System: java.io.PrintStream out>;
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>("Starting setup of dynamic connection for database: Postgres ");
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.testcontainers.containers.PostgreSQLContainer postgreSQLContainer>;
virtualinvoke v.<org.testcontainers.containers.PostgreSQLContainer: org.testcontainers.containers.JdbcDatabaseContainer withInitScript(java.lang.String)>("postgres/init.sql");
v = v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.testcontainers.containers.PostgreSQLContainer postgreSQLContainer>;
virtualinvoke v.<org.testcontainers.containers.PostgreSQLContainer: void start()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.testcontainers.containers.PostgreSQLContainer postgreSQLContainer>;
v = virtualinvoke v.<org.testcontainers.containers.PostgreSQLContainer: java.lang.String getHost()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.testcontainers.containers.PostgreSQLContainer postgreSQLContainer>;
v = <org.testcontainers.containers.PostgreSQLContainer: java.lang.Integer POSTGRESQL_PORT>;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = virtualinvoke v.<org.testcontainers.containers.PostgreSQLContainer: java.lang.Integer getMappedPort(int)>(v);
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = <java.lang.System: java.io.PrintStream out>;
v = v - v;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int,long)>(v, v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Completed setup of dynamic connection for database: Postgres on host:\u and port:\u , time taken(ms):\u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
return;
}
private void registerVault()
{
org.finos.legend.engine.shared.core.vault.PropertiesVaultImplementation v;
java.util.Properties v;
org.finos.legend.engine.shared.core.vault.VaultImplementation v;
org.finos.legend.engine.shared.core.vault.Vault v;
org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration;
v = new java.util.Properties;
specialinvoke v.<java.util.Properties: void <init>()>();
virtualinvoke v.<java.util.Properties: java.lang.Object put(java.lang.Object,java.lang.Object)>("postgresql.user", "test");
virtualinvoke v.<java.util.Properties: java.lang.Object put(java.lang.Object,java.lang.Object)>("postgresql.password", "test");
v = new org.finos.legend.engine.shared.core.vault.PropertiesVaultImplementation;
specialinvoke v.<org.finos.legend.engine.shared.core.vault.PropertiesVaultImplementation: void <init>(java.util.Properties)>(v);
v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.finos.legend.engine.shared.core.vault.VaultImplementation vaultImplementation> = v;
v = <org.finos.legend.engine.shared.core.vault.Vault: org.finos.legend.engine.shared.core.vault.Vault INSTANCE>;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: org.finos.legend.engine.shared.core.vault.VaultImplementation vaultImplementation>;
virtualinvoke v.<org.finos.legend.engine.shared.core.vault.Vault: void registerImplementation(org.finos.legend.engine.shared.core.vault.VaultImplementation)>(v);
return;
}
public void start() throws java.lang.Exception
{
org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration;
virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: void setup()>();
return;
}
public void shutDown() throws java.lang.Exception
{
org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration;
virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.test.postgres.integration.PostgresTestConnectionIntegration: void cleanup()>();
return;
}
}