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

org.specrunner.hibernate4.PluginSchemaExport Maven / Gradle / Ivy

/*
    SpecRunner - Acceptance Test Driven Development Tool
    Copyright (C) 2011-2016  Thiago Santos

    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    This program 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 General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program.  If not, see 
 */
package org.specrunner.hibernate4;

import org.hibernate.HibernateException;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
import org.specrunner.context.IContext;
import org.specrunner.parameters.DontEval;
import org.specrunner.plugins.ActionType;
import org.specrunner.plugins.ENext;
import org.specrunner.plugins.PluginException;
import org.specrunner.plugins.core.AbstractPlugin;
import org.specrunner.plugins.type.Command;
import org.specrunner.result.IResultSet;
import org.specrunner.result.status.Failure;
import org.specrunner.result.status.Success;
import org.specrunner.util.UtilLog;

/**
 * Creates a schema based on Hibernate annotated classes.
 * 
 * @author Thiago Santos
 * 
 */
public class PluginSchemaExport extends AbstractPlugin {

    /**
     * The configuration name.
     */
    protected String configuration;
    /**
     * The factory name.
     */
    protected String factory;
    /**
     * The schema name.
     */
    protected String schema;
    /**
     * To show/generate script.
     */
    protected boolean script = false;
    /**
     * To drop schema.
     */
    protected boolean drop = true;
    /**
     * To export/update schema.
     */
    protected boolean export = true;

    /**
     * Name of configuration to be used.
     * 
     * @return The configuration name, if not set
     *         PluginConnection.SESSION_CONFIGURATION will be used.
     */
    public String getConfiguration() {
        return configuration;
    }

    /**
     * Set the configuration.
     * 
     * @param configuration
     *            A configuration.
     */
    @DontEval
    public void setConfiguration(String configuration) {
        this.configuration = configuration;
    }

    /**
     * Name of session factory to be used.
     * 
     * @return The session factory name, if not set
     *         PluginConnection.SESSION_FACTORY will be used.
     */
    public String getFactory() {
        return factory;
    }

    /**
     * Set a session factory.
     * 
     * @param factory
     *            A factory.
     */
    public void setFactory(String factory) {
        this.factory = factory;
    }

    /**
     * Gets the schema name.
     * 
     * @return The schema name.
     */
    public String getSchema() {
        return schema;
    }

    /**
     * Set the default schema.
     * 
     * @param schema
     *            The schema.
     */
    @DontEval
    public void setSchema(String schema) {
        this.schema = schema;
    }

    /**
     * true, if script must be writen to System.out. Default is
     * 'false'.
     * 
     * @return true, if show script, false, otherwise.
     */
    public boolean isScript() {
        return script;
    }

    /**
     * Set script output status.
     * 
     * @param script
     *            true, for show, false, otherwise.
     */
    public void setScript(boolean script) {
        this.script = script;
    }

    /**
     * true, if schema has to be dropped, false, otherwise. Default is true.
     * 
     * @return Schema drop mode.
     */
    public boolean isDrop() {
        return drop;
    }

    /**
     * Set the drop behavior.
     * 
     * @param drop
     *            The drop behavior flag.
     */
    public void setDrop(boolean drop) {
        this.drop = drop;
    }

    /**
     * true, to perform schema creation on database, false, otherwise. Default
     * is 'true'.
     * 
     * @return true, if export is enabled, false, otherwise.
     */
    public boolean isExport() {
        return export;
    }

    /**
     * Sets export status.
     * 
     * @param export
     *            The export status.
     */
    public void setExport(boolean export) {
        this.export = export;
    }

    @Override
    public ActionType getActionType() {
        return Command.INSTANCE;
    }

    @Override
    public ENext doStart(IContext context, IResultSet result) throws PluginException {
        Configuration cfg = PluginConfiguration.getConfiguration(context, getConfiguration());
        if (isDrop()) {
            SessionFactory sessionFactory = PluginSessionFactory.getSessionFactory(context, getFactory());
            dropSchema(context, sessionFactory);
            createSchema(context, sessionFactory);
        }
        try {
            new SchemaExport(cfg).create(isScript(), isExport());
            result.addResult(Success.INSTANCE, context.peek());
        } catch (HibernateException e) {
            result.addResult(Failure.INSTANCE, context.peek(), e);
        }
        return ENext.DEEP;
    }

    /**
     * Perform drop schema.
     * 
     * @param context
     *            The context.
     * @param sf
     *            The session factory.
     * @throws PluginException
     *             On drop errors.
     */
    protected void dropSchema(IContext context, SessionFactory sf) throws PluginException {
        Session s = null;
        try {
            s = sf.openSession();
            try {
                String str = "drop schema " + getSchema() + " cascade";
                SQLQuery sql = s.createSQLQuery(str);
                if (UtilLog.LOG.isInfoEnabled()) {
                    UtilLog.LOG.info(str);
                }
                sql.executeUpdate();
            } catch (Throwable e) {
                if (UtilLog.LOG.isDebugEnabled()) {
                    UtilLog.LOG.debug(e.getMessage(), e);
                }
            }
        } finally {
            if (s != null) {
                s.close();
            }
        }
    }

    /**
     * Perform create schema.
     * 
     * @param context
     *            The context.
     * @param sf
     *            The session factory.
     * @throws PluginException
     *             On creation errors.
     */
    protected void createSchema(IContext context, SessionFactory sf) throws PluginException {
        Session s = null;
        try {
            s = sf.openSession();
            try {
                String str = "create schema " + getSchema() + " authorization dba";
                SQLQuery sql = s.createSQLQuery(str);
                if (UtilLog.LOG.isInfoEnabled()) {
                    UtilLog.LOG.info(str);
                }
                sql.executeUpdate();
            } catch (Exception e) {
                if (UtilLog.LOG.isDebugEnabled()) {
                    UtilLog.LOG.debug(e.getMessage(), e);
                }
            }
        } finally {
            if (s != null) {
                s.close();
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy