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

com.googlecode.flyway.maven.MigrationDumper Maven / Gradle / Ivy

/**
 * Copyright (C) 2009-2010 the original author or authors.
 *
 * 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 com.googlecode.flyway.maven;

import com.googlecode.flyway.core.migration.Migration;
import com.googlecode.flyway.core.util.StringUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;

/**
 * Dumps migrations in an ascii-art table in the logs and the Maven console.
 */
public class MigrationDumper {
    /**
     * Logger.
     */
    private static final Log LOG = LogFactory.getLog(MigrationDumper.class);

    /**
     * Prevent instantiation.
     */
    private MigrationDumper() {
        // Do nothing
    }

    /**
     * Dumps this list of migrations in the log file.
     *
     * @param migrations The list of migrations to dump.
     */
    public static void dumpMigrations(List migrations) {
        LOG.info("+-------------+------------------------+---------------------+---------+");
        LOG.info("| Version     | Description            | Installed on        | State   |");
        LOG.info("+-------------+------------------------+---------------------+---------+");

        if (migrations.isEmpty()) {
            LOG.info("| No migrations applied yet                                            |");
        } else {
            for (Migration migration : migrations) {
                LOG.info("| " + StringUtils.trimOrPad(migration.getVersion().getVersion(), 11)
                        + " | " + StringUtils.trimOrPad(migration.getVersion().getDescription(), 22)
                        + " | " + StringUtils.trimOrPad(formatInstalledOnDate(migration.getInstalledOn()), 19)
                        + " | " + StringUtils.trimOrPad(migration.getState().name(), 7) + " |");
            }
        }

        LOG.info("+-------------+------------------------+---------------------+---------+");
    }

    /**
     * Formats the installedOn date for displaying it in the table.
     *
     * @param installedOn The date to format.
     * @return The date in a displayable format.
     */
    private static String formatInstalledOnDate(Date installedOn) {
        return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(installedOn);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy