/* * ModeShape (http://www.modeshape.org) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.modeshape.connector.meta.jdbc; import static org.hamcrest.core.Is.is; import static org.hamcrest.core.IsNull.notNullValue; import static org.junit.Assert.assertThat; import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.sql.Connection; import java.sql.Statement; import javax.naming.Context; import javax.naming.InitialContext; import javax.naming.NamingException; import javax.sql.DataSource; import org.modeshape.jcr.store.DataSourceConfig; import com.zaxxer.hikari.HikariDataSource; /** * Test helper which executes DDL statements from a file against a given datasource. */ public class DatasourceHelper { private static final DataSourceConfig DATA_SOURCE_CONFIG = new DataSourceConfig(); private static HikariDataSource dataSource; private static boolean print = false; /** * Sets a flag which allows debug-type information to be printed. * * @param print a boolean flag */ public static void setPrint( boolean print ) { DatasourceHelper.print = print; } /** * Runs the ddl contained in the given filename, against the given data source. * * @param fileName a non-null string * @throws Exception if anything fails */ public static void executeDdl( String fileName ) throws Exception { Connection conn = null; Statement stmt = null; InputStream istream = null; BufferedReader reader = null; try { conn = dataSource.getConnection(); stmt = conn.createStatement(); String filePath = "/" + DATA_SOURCE_CONFIG.getDatabase() + "/" + fileName; istream = DatasourceHelper.class.getResourceAsStream(filePath); assertThat(filePath + " cannot be found", istream, is(notNullValue())); reader = new BufferedReader(new InputStreamReader(istream)); /* * We have to send the DDL line-at-a-time because the MySQL driver doesn't like getting multiple DDL statements at once */ String line; while ((line = reader.readLine()) != null) { line = line.trim(); if (line.length() > 0 && !line.startsWith("--")) { if (print) { System.out.println("Executing: " + line); } stmt.execute(line); } } } finally { if (stmt != null) { try { stmt.close(); } catch (Exception ignore) { } } if (conn != null) { try { conn.close(); } catch (Exception ignore) { } } if (istream != null) { try { istream.close(); } catch (Exception ignore) { } } } } /** * Creates a data source using C3P0. * * @return a {@link DataSource} instance, never {@code null} */ public static DataSource getDataSource() { if (dataSource == null) { dataSource = new HikariDataSource(); dataSource.setDriverClassName(DATA_SOURCE_CONFIG.getDriverClassName()); dataSource.setJdbcUrl(DATA_SOURCE_CONFIG.getUrl()); dataSource.setUsername(DATA_SOURCE_CONFIG.getUsername()); dataSource.setPassword(DATA_SOURCE_CONFIG.getPassword()); dataSource.setIdleTimeout(DATA_SOURCE_CONFIG.getMaximumConnectionIdleTimeInSeconds() * 1000); dataSource.setMaximumPoolSize(DATA_SOURCE_CONFIG.getMaximumConnectionsInPool()); } return dataSource; } public static void bindInJNDI( String name ) throws NamingException { // Create initial context System.setProperty(Context.INITIAL_CONTEXT_FACTORY, "org.apache.commons.naming.java.javaURLContextFactory"); System.setProperty(Context.URL_PKG_PREFIXES, "org.apache.naming"); InitialContext ic = new InitialContext(); ic.createSubcontext("java:"); ic.bind("java:/" + name, dataSource); } public static void closeDataSource() { dataSource.close(); } }