package org.javers.core.diff.appenders;
import org.javers.core.diff.NodePair;
import org.javers.core.diff.changetype.PropertyChange;
import org.javers.core.metamodel.property.Property;
import org.javers.core.metamodel.type.CollectionType;
import org.javers.core.metamodel.type.JaversType;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.Collection;
import java.util.Objects;
/**
* @author bartosz.walacik
*/
public class CollectionChangeFakeAppender extends CorePropertyChangeAppender<PropertyChange> {
private static final Logger logger = LoggerFactory.getLogger(CollectionChangeFakeAppender.class);
@Override
public boolean supports(JaversType propertyType) {
return propertyType.getClass() == CollectionType.class;
}
@Override
public PropertyChange calculateChanges(NodePair pair, Property property) {
Collection leftCol = (Collection) pair.getLeftPropertyValue(property);
Collection rightCol = (Collection) pair.getRightPropertyValue(property);
if (!Objects.equals(leftCol, rightCol)) {
logger.warn("Collections: " + property + "\n"+
"are not equals but can't be compared. " +
"Raw Collection properties are not supported. Expected Set, List or any of their subclasses. "+
"JaVers uses different algorithms for comparing Sets and Lists and needs to know (statically) which one to test.");
}
return null;
}
@Override
public int priority() {
return super.priority();
}
}