use of com.axway.ats.core.dbaccess.mariadb.DbConnMariaDB in project ats-framework by Axway.
the class Test_DatabaseProviderFactory_createDbConnection method createMariaDbNoCustom.
@Test
public void createMariaDbNoCustom() {
DbConnMariaDB dbConnection = (DbConnMariaDB) DatabaseProviderFactory.createDbConnection(DbConnMariaDB.DATABASE_TYPE, "host", DbConnMySQL.DEFAULT_PORT, "db", "user", "pass");
assertEquals(DbConnMariaDB.DATABASE_TYPE, dbConnection.getDbType());
assertEquals("host", dbConnection.getHost());
assertEquals("db", dbConnection.getDb());
assertEquals("user", dbConnection.getUser());
assertEquals("pass", dbConnection.getPassword());
assertEquals("jdbc:mariadb://host:" + DbConnMySQL.DEFAULT_PORT + "/db", dbConnection.getURL());
}
use of com.axway.ats.core.dbaccess.mariadb.DbConnMariaDB in project ats-framework by Axway.
the class Test_DatabaseProviderFactory_createDbConnection method createMariaDbWithCustomProperties.
@Test
public void createMariaDbWithCustomProperties() {
Map<String, Object> customProperties = new HashMap<String, Object>();
customProperties.put(DbKeys.PORT_KEY, 123);
DbConnMariaDB dbConnection = (DbConnMariaDB) DatabaseProviderFactory.createDbConnection(DbConnMariaDB.DATABASE_TYPE, "host", DbConnMariaDB.DEFAULT_PORT, "db", "user", "pass", customProperties);
assertEquals(DbConnMariaDB.DATABASE_TYPE, dbConnection.getDbType());
assertEquals("host", dbConnection.getHost());
assertEquals("db", dbConnection.getDb());
assertEquals("user", dbConnection.getUser());
assertEquals("pass", dbConnection.getPassword());
assertEquals("jdbc:mariadb://host:123/db", dbConnection.getURL());
}
use of com.axway.ats.core.dbaccess.mariadb.DbConnMariaDB in project ats-framework by Axway.
the class DatabaseProviderFactory method getDatabaseProvider.
/**
* Creates a database provider suitable for the given input arguments
*
* @param dbType
* @param dbHost
* @param dbName
* @param dbUser
* @param dbPass
* @param dbPort
* @param customProperties
* @return
*/
public static synchronized DbProvider getDatabaseProvider(String dbType, String dbHost, String dbName, String dbUser, String dbPass, int dbPort, Map<String, Object> customProperties) {
DbProvider dbProvider;
if (dbType == null) {
throw new IllegalArgumentException("Database type is not provided");
}
dbType = dbType.toUpperCase();
if (dbName == null) {
if ("MSSQL".equals(dbType)) {
log.warn("Database name is empty! The connection will be made to the admin database!");
} else {
throw new IllegalArgumentException("Database name is not provided");
}
}
// eventual custom property value
if (dbPort > 0) {
if (customProperties == null) {
customProperties = new HashMap<String, Object>();
}
customProperties.put(DbKeys.PORT_KEY, dbPort);
}
// load a custom data provider
if (dbProviders.containsKey(dbType)) {
String[] classNames = dbProviders.get(dbType);
DbConnection dbConnection = loadDbConnection(classNames[0], dbType, dbHost, dbName, dbUser, dbPass, dbPort, customProperties);
return loadCustomDbProvider(classNames[1], dbConnection);
}
// load a common ATS supported data provider
switch(dbType) {
case DbConnSQLServer.DATABASE_TYPE:
dbProvider = new MssqlDbProvider((DbConnSQLServer) createDbConnection(dbType, dbHost, dbPort, dbName, dbUser, dbPass, customProperties));
break;
case DbConnPostgreSQL.DATABASE_TYPE:
dbProvider = new PostgreSqlDbProvider((DbConnPostgreSQL) createDbConnection(dbType, dbHost, dbPort, dbName, dbUser, dbPass, customProperties));
break;
case DbConnMySQL.DATABASE_TYPE:
dbProvider = new MysqlDbProvider((DbConnMySQL) createDbConnection(dbType, dbHost, dbPort, dbName, dbUser, dbPass, customProperties));
break;
case DbConnMariaDB.DATABASE_TYPE:
dbProvider = new MariaDbDbProvider((DbConnMariaDB) createDbConnection(dbType, dbHost, dbPort, dbName, dbUser, dbPass, customProperties));
break;
case DbConnOracle.DATABASE_TYPE:
dbProvider = new OracleDbProvider((DbConnOracle) createDbConnection(dbType, dbHost, dbPort, dbName, dbUser, dbPass, customProperties));
break;
case DbConnCassandra.DATABASE_TYPE:
dbProvider = new CassandraDbProvider((DbConnCassandra) createDbConnection(dbType, dbHost, dbPort, dbName, dbUser, dbPass, customProperties));
break;
default:
{
// should never happen
throw new IllegalArgumentException("Database type " + dbType + " not supported");
}
}
return dbProvider;
}
Aggregations