
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