mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-30 18:15:39 +00:00
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@32385 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
107 lines
3.9 KiB
Java
107 lines
3.9 KiB
Java
/*
|
|
* Copyright (C) 2005-2011 Alfresco Software Limited.
|
|
*
|
|
* This file is part of Alfresco
|
|
*
|
|
* Alfresco is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Alfresco is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
package org.alfresco.util.schemacomp;
|
|
|
|
|
|
import javax.sql.DataSource;
|
|
|
|
import org.alfresco.util.ApplicationContextHelper;
|
|
import org.alfresco.util.schemacomp.model.Schema;
|
|
import org.alfresco.util.schemacomp.test.exportdb.AbstractExportTester;
|
|
import org.alfresco.util.schemacomp.test.exportdb.MySQLDialectExportTester;
|
|
import org.alfresco.util.schemacomp.test.exportdb.PostgreSQLDialectExportTester;
|
|
import org.apache.commons.logging.Log;
|
|
import org.apache.commons.logging.LogFactory;
|
|
import org.hibernate.dialect.Dialect;
|
|
import org.hibernate.dialect.MySQLDialect;
|
|
import org.hibernate.dialect.PostgreSQLDialect;
|
|
import org.junit.Before;
|
|
import org.junit.Test;
|
|
import org.springframework.context.ApplicationContext;
|
|
import org.springframework.jdbc.core.simple.SimpleJdbcTemplate;
|
|
import org.springframework.transaction.PlatformTransactionManager;
|
|
|
|
/**
|
|
* Tests for the ExportDb class. Loads the database into an in-memory {@link Schema} representation.
|
|
* <p>
|
|
* This test is DBMS specific, if the test is run on a system configured against MySQL for example,
|
|
* it will run MySQL specific tests. If there is no test available for the configured DBMS then
|
|
* the test will pass - this allows addition of new DBMS-specific tests when available.
|
|
*
|
|
* @author Matt Ward
|
|
*/
|
|
public class ExportDbTest
|
|
{
|
|
private ApplicationContext ctx;
|
|
private ExportDb exporter;
|
|
private Dialect dialect;
|
|
private DataSource dataSource;
|
|
private SimpleJdbcTemplate jdbcTemplate;
|
|
private PlatformTransactionManager tx;
|
|
private AbstractExportTester exportTester;
|
|
private static final Log logger = LogFactory.getLog(ExportDbTest.class);
|
|
|
|
|
|
@Before
|
|
public void setUp() throws Exception
|
|
{
|
|
ctx = ApplicationContextHelper.getApplicationContext();
|
|
dataSource = (DataSource) ctx.getBean("dataSource");
|
|
tx = (PlatformTransactionManager) ctx.getBean("transactionManager");
|
|
jdbcTemplate = new SimpleJdbcTemplate(dataSource);
|
|
exporter = new ExportDb(ctx);
|
|
exporter.setNamePrefix("export_test_");
|
|
dialect = (Dialect) ctx.getBean("dialect");
|
|
}
|
|
|
|
|
|
@Test
|
|
public void exportDb() throws Exception
|
|
{
|
|
Class dialectClass = dialect.getClass();
|
|
|
|
if (logger.isDebugEnabled())
|
|
{
|
|
logger.debug("Using dialect class " + dialectClass.getName());
|
|
}
|
|
|
|
if (PostgreSQLDialect.class.isAssignableFrom(dialectClass))
|
|
{
|
|
exportTester = new PostgreSQLDialectExportTester(exporter, tx, jdbcTemplate);
|
|
}
|
|
else if (MySQLDialect.class.isAssignableFrom(dialectClass))
|
|
{
|
|
exportTester = new MySQLDialectExportTester(exporter, tx, jdbcTemplate);
|
|
}
|
|
|
|
if (exportTester != null)
|
|
{
|
|
// Run the DBMS specific tests.
|
|
exportTester.runExportTest();
|
|
}
|
|
else
|
|
{
|
|
if (logger.isInfoEnabled())
|
|
{
|
|
logger.info("Unsupported dialect for this test " + dialectClass.getName());
|
|
}
|
|
}
|
|
}
|
|
}
|