All Downloads are FREE. Search and download functionalities are using the official Maven repository.

liquibase.sdk.supplier.database.AllDatabases Maven / Gradle / Ivy

There is a newer version: 4.31.0
Show newest version
package liquibase.sdk.supplier.database;

import liquibase.database.Database;
import liquibase.database.DatabaseConnection;
import liquibase.database.DatabaseFactory;
import liquibase.database.jvm.JdbcConnection;
import liquibase.exception.DatabaseException;
import org.junit.experimental.theories.ParameterSignature;
import org.junit.experimental.theories.ParameterSupplier;
import org.junit.experimental.theories.PotentialAssignment;

import java.sql.Connection;
import java.sql.Driver;
import java.sql.SQLException;
import java.util.*;

import static junit.framework.Assert.assertNotNull;

public class AllDatabases extends ParameterSupplier {

    private Map connectionsAttempted = new HashMap();
    private Map connectionsByUrl = new HashMap();

    @Override
    public List getValueSources(ParameterSignature sig) {
        List returnList = new ArrayList();
        for (Database database :  DatabaseFactory.getInstance().getImplementedDatabases()) {
            for (ConnectionSupplier config : ConnectionConfigurationFactory.getInstance().getConfigurations(database)) {
                database.setConnection(openConnection(config));
                returnList.add(PotentialAssignment.forValue(database.getShortName()+" - "+config.getConfigurationName(), database));
            }
        }

        return returnList;
    }

    protected DatabaseConnection openConnection(ConnectionSupplier connectionConfig) {
        try {
            final String url = connectionConfig.getJdbcUrl();
            if (connectionsAttempted.containsKey(url)) {
                JdbcConnection connection = (JdbcConnection) connectionsByUrl.get(url);
                if (connection == null) {
                    return null;
                } else if (connection.getUnderlyingConnection().isClosed()){
                    connectionsByUrl.put(url, openDatabaseConnection(connectionConfig));
                }
                return connectionsByUrl.get(url);
            }
            connectionsAttempted.put(url, Boolean.TRUE);


            final DatabaseConnection connection = openDatabaseConnection(connectionConfig);
            if (connection == null) {
                return null;
            }

//            try {
//                if (url.startsWith("jdbc:hsql")) {
//                    ((JdbcConnection) databaseConnection).getUnderlyingConnection().createStatement().execute("CREATE SCHEMA " + ALT_SCHEMA + " AUTHORIZATION DBA");
//                } else if (url.startsWith("jdbc:sqlserver")
//                        || url.startsWith("jdbc:postgresql")
//                        || url.startsWith("jdbc:h2")) {
//                    ((JdbcConnection) databaseConnection).getUnderlyingConnection().createStatement().execute("CREATE SCHEMA " + ALT_SCHEMA);
//                }
//                if (!databaseConnection.getAutoCommit()) {
//                    databaseConnection.commit();
//                }
//            } catch (SQLException e) {
////            e.printStackTrace();
//                ; //schema already exists
//            } finally {
//                try {
//                    databaseConnection.rollback();
//                } catch (DatabaseException e) {
//                    if (database instanceof DB2Database) {
////                    expected, there is a problem with it
//                    } else {
//                        throw e;
//                    }
//                }
//            }

            connectionsByUrl.put(url, connection);

            Runtime.getRuntime().addShutdownHook(new Thread(new Runnable() {

                @Override
                public void run() {
                    try {
                        try {
                            if (!((JdbcConnection) connection).getUnderlyingConnection().getAutoCommit()) {
                                ((JdbcConnection) connection).getUnderlyingConnection().rollback();
                            }
                        } catch (SQLException e) {
                            ;
                        }


                        ((JdbcConnection) connection).getUnderlyingConnection().close();
                    } catch (SQLException e) {
                        System.out.println("Could not close " + url);
                        e.printStackTrace();
                    }
                }
            }));

            return connectionsByUrl.get(url);

        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }

    }

    public DatabaseConnection openDatabaseConnection(ConnectionSupplier connectionSupplier) throws Exception {
        String url = connectionSupplier.getJdbcUrl();
        assertNotNull("Null jdbc url", url);

        String username = connectionSupplier.getDatabaseUsername();
        String password = connectionSupplier.getDatabasePassword();


        JDBCDriverClassLoader jdbcDriverLoader = new JDBCDriverClassLoader();
        final Driver driver;
        try {
            String defaultDriver = DatabaseFactory.getInstance().findDefaultDriver(url);
            driver = (Driver) Class.forName(defaultDriver, true, jdbcDriverLoader).newInstance();
        } catch (Exception e) {
            System.out.println("Error finding default driver for " + url + ": Will not test against.  " + e.getMessage());
            return null; //could not connect
        }

        Properties info = new Properties();
        info.put("user", username);
        if (password != null) {
            info.put("password", password);
        }
        info.put("retrieveMessagesFromServerOnGetMessage", "true"); //for db2


        Connection connection;
        try {
            connection = driver.connect(url, info);
        } catch (SQLException e) {
            System.out.println("Could not connect to " + url + ": Will not test against.  " + e.getMessage());
            return null; //could not connect
        }
        if (connection == null) {
            throw new DatabaseException("Connection could not be created to " + url + " with driver " + driver.getClass().getName() + ".  Possibly the wrong driver for the given database URL");
        }

        return new JdbcConnection(connection);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy