public class org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers extends java.lang.Object implements org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.TestConnectionIntegration
{
public org.testcontainers.containers.MSSQLServerContainer mssqlserver;
private org.finos.legend.engine.shared.core.vault.VaultImplementation vaultImplementation;
public void <init>()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers v;
org.testcontainers.containers.MSSQLServerContainer v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.testcontainers.containers.MSSQLServerContainer;
specialinvoke v.<org.testcontainers.containers.MSSQLServerContainer: void <init>(java.lang.String)>("mcr.microsoft.com/mssql/server:2019-latest");
v = virtualinvoke v.<org.testcontainers.containers.MSSQLServerContainer: org.testcontainers.containers.MSSQLServerContainer acceptLicense()>();
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: org.testcontainers.containers.MSSQLServerContainer mssqlserver> = v;
return;
}
public org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType getDatabaseType()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.DatabaseType v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers;
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 SqlServer>;
return v;
}
public org.eclipse.collections.api.list.MutableList group()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers v;
java.lang.String[] v;
org.eclipse.collections.api.factory.list.MutableListFactory v;
org.eclipse.collections.api.list.MutableList v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers;
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] = "SqlServer";
v = interfaceinvoke v.<org.eclipse.collections.api.factory.list.MutableListFactory: org.eclipse.collections.api.list.MutableList 'with'(java.lang.Object[])>(v);
return v;
}
public void setup()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers;
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: void startMSSQLServerContainer()>();
virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: void registerVault()>();
return;
}
private void startMSSQLServerContainer()
{
java.io.PrintStream v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers v;
long v, v, v;
java.lang.Integer v, v;
org.testcontainers.containers.MSSQLServerContainer v, v, v;
int v, v;
java.lang.String v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers;
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: SqlServer ");
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: org.testcontainers.containers.MSSQLServerContainer mssqlserver>;
virtualinvoke v.<org.testcontainers.containers.MSSQLServerContainer: void start()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: org.testcontainers.containers.MSSQLServerContainer mssqlserver>;
v = virtualinvoke v.<org.testcontainers.containers.MSSQLServerContainer: java.lang.String getHost()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: org.testcontainers.containers.MSSQLServerContainer mssqlserver>;
v = <org.testcontainers.containers.MSSQLServerContainer: java.lang.Integer MS_SQL_SERVER_PORT>;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = virtualinvoke v.<org.testcontainers.containers.MSSQLServerContainer: 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: SqlServer on host:\u and port:\u , time taken(ms):\u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
return;
}
public void registerVault()
{
org.finos.legend.engine.shared.core.vault.PropertiesVaultImplementation v;
org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers v;
java.util.Properties v;
org.finos.legend.engine.shared.core.vault.VaultImplementation v;
org.finos.legend.engine.shared.core.vault.Vault v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers;
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)>("sqlServerAccount.user", "SA");
virtualinvoke v.<java.util.Properties: java.lang.Object put(java.lang.Object,java.lang.Object)>("sqlServerAccount.password", "A_Str0ng_Required_Password");
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.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: 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.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: 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 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.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers 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;
java.lang.Integer v, v;
org.finos.legend.engine.protocol.pure.v.model.packageableElement.store.relational.connection.RelationalDatabaseConnection v;
org.testcontainers.containers.MSSQLServerContainer v, v;
int v, v;
java.lang.String v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers;
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.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: org.testcontainers.containers.MSSQLServerContainer mssqlserver>;
v = virtualinvoke v.<org.testcontainers.containers.MSSQLServerContainer: 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.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: org.testcontainers.containers.MSSQLServerContainer mssqlserver>;
v = <org.testcontainers.containers.MSSQLServerContainer: java.lang.Integer MS_SQL_SERVER_PORT>;
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
v = virtualinvoke v.<org.testcontainers.containers.MSSQLServerContainer: 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> = "master";
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> = "sqlServerAccount.";
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 SqlServer>;
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 SqlServer>;
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> = "";
return v;
}
public void cleanup()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers v;
org.testcontainers.containers.MSSQLServerContainer v;
org.finos.legend.engine.shared.core.vault.VaultImplementation v;
org.finos.legend.engine.shared.core.vault.Vault v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.tests.api.dynamicTestConnections.SqlServerTestContainers;
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.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: 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.connection.tests.api.dynamicTestConnections.SqlServerTestContainers: org.testcontainers.containers.MSSQLServerContainer mssqlserver>;
virtualinvoke v.<org.testcontainers.containers.MSSQLServerContainer: void stop()>();
return;
}
}