mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-30 18:15:39 +00:00
The differences and validation messages are hopefully improved, e.g: Difference: missing sequence from database, expected at path: .alf_acl_member_seq Difference: missing table from database, expected at path: .alf_acl_change_set Validation: index alfresco.some_table.idx_table_id.name="idx_table_id" fails to match rule: value must be 'xyz' I'm sure there's still room for improvement but this should give a decent starting point. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@32420 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
120 lines
3.4 KiB
Java
120 lines
3.4 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 org.springframework.extensions.surf.util.I18NUtil;
|
|
|
|
|
|
|
|
/**
|
|
* Result of a comparison between two database objects.
|
|
*
|
|
* @author Matt Ward
|
|
*/
|
|
public final class Difference extends Result
|
|
{
|
|
/** Specifies the type of differences */
|
|
public enum Where { ONLY_IN_REFERENCE, ONLY_IN_TARGET, IN_BOTH_NO_DIFFERENCE, IN_BOTH_BUT_DIFFERENCE };
|
|
private final Where where;
|
|
private final DbProperty left;
|
|
private final DbProperty right;
|
|
|
|
|
|
public Difference(Where where, DbProperty left, DbProperty right)
|
|
{
|
|
this(where, left, right, null);
|
|
}
|
|
|
|
public Difference(Where where, DbProperty left, DbProperty right, Strength strength)
|
|
{
|
|
super(null);
|
|
|
|
// Sanity check parameters
|
|
if (left == null && right == null)
|
|
{
|
|
throw new IllegalArgumentException("DbProperty parameters cannot BOTH be null.");
|
|
}
|
|
|
|
this.where = where;
|
|
this.left = left;
|
|
this.right = right;
|
|
}
|
|
|
|
/**
|
|
* @return the where
|
|
*/
|
|
public Where getWhere()
|
|
{
|
|
return this.where;
|
|
}
|
|
|
|
/**
|
|
* @return the left
|
|
*/
|
|
public DbProperty getLeft()
|
|
{
|
|
return this.left;
|
|
}
|
|
|
|
/**
|
|
* @return the right
|
|
*/
|
|
public DbProperty getRight()
|
|
{
|
|
return this.right;
|
|
}
|
|
|
|
|
|
@Override
|
|
public String describe()
|
|
{
|
|
if (getLeft() == null)
|
|
{
|
|
return I18NUtil.getMessage(
|
|
"system.schema_comp.diff.target_only",
|
|
getRight().getDbObject().getTypeName(),
|
|
getRight().getPath(),
|
|
getRight().getPropertyValue());
|
|
}
|
|
if (getRight() == null)
|
|
{
|
|
return I18NUtil.getMessage(
|
|
"system.schema_comp.diff.ref_only",
|
|
getLeft().getDbObject().getTypeName(),
|
|
getLeft().getPath(),
|
|
getLeft().getPropertyValue());
|
|
}
|
|
|
|
return I18NUtil.getMessage(
|
|
"system.schema_comp.diff",
|
|
getLeft().getDbObject().getTypeName(),
|
|
getLeft().getPath(),
|
|
getLeft().getPropertyValue(),
|
|
getRight().getPath(),
|
|
getRight().getPropertyValue());
|
|
}
|
|
|
|
@Override
|
|
public String toString()
|
|
{
|
|
return "Difference [where=" + this.where + ", left=" + this.left + ", right=" + this.right
|
|
+ ", strength=" + this.strength + "]";
|
|
}
|
|
}
|