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

com.gs.obevocomparer.output.simple.SimpleComparisonMetadata Maven / Gradle / Ivy

/**
 * Copyright 2017 Goldman Sachs.
 * 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.gs.obevocomparer.output.simple;

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;

import com.gs.obevocomparer.compare.CatoComparison;
import com.gs.obevocomparer.compare.CatoDataSide;
import com.gs.obevocomparer.compare.breaks.Break;
import com.gs.obevocomparer.compare.breaks.FieldBreak;
import com.gs.obevocomparer.compare.breaks.GroupBreak;
import com.gs.obevocomparer.output.CatoComparisonMetadata;

public class SimpleComparisonMetadata implements CatoComparisonMetadata {

    private final CatoComparison comparison;

    private final Set leftFields = new LinkedHashSet();
    private final Set rightFields = new LinkedHashSet();

    private final Set fieldBreakFields = new LinkedHashSet();
    private final Set includedFieldBreakFields = new LinkedHashSet();
    private final Set excludedFieldBreakFields = new LinkedHashSet();
    private final Set groupBreakFields = new LinkedHashSet();

    private int includedBreakSize = 0;
    private int excludedBreakSize = 0;
    private boolean hasGroupBreaks;

    private final Map breakTypeInfoMap = new HashMap();

    public SimpleComparisonMetadata(CatoComparison comparison) {

        this.comparison = comparison;

        FieldBreak fbr;
        String extraRecordBreak = "Only in " + comparison.getLeftDataSource().getShortName();
        String missingRecordBreak = "Only in " + comparison.getRightDataSource().getShortName();

        for (Break br : comparison.getBreaks()) {
            if (br.isExcluded()) {
                this.excludedBreakSize++;
            } else {
                this.includedBreakSize++;
            }

            if (br.getDataSide() == CatoDataSide.LEFT) {
                this.leftFields.addAll(br.getDataObject().getFields());
            } else if (br.getDataSide() == CatoDataSide.RIGHT) {
                this.rightFields.addAll(br.getDataObject().getFields());
            }

            if (br instanceof FieldBreak) {
                fbr = (FieldBreak) br;
                for (String field : fbr.getFields()) {
                    this.fieldBreakFields.add(field);

                    if (fbr.isExcluded(field)) {
                        this.excludedFieldBreakFields.add(field);
                    } else {
                        this.includedFieldBreakFields.add(field);
                    }

                    this.addBreakStat(field, fbr.isExcluded(field));
                }
            } else {
                if (br.getDataSide() == CatoDataSide.LEFT) {
                    this.addBreakStat(extraRecordBreak, br.isExcluded());
                } else if (br.getDataSide() == CatoDataSide.RIGHT) {
                    this.addBreakStat(missingRecordBreak, br.isExcluded());
                }
            }

            if (br instanceof GroupBreak) {
                this.hasGroupBreaks = true;
                this.groupBreakFields.addAll(((GroupBreak) br).getFields());
            }
        }
    }

    public CatoComparison getComparison() {
        return this.comparison;
    }

    private void addBreakStat(String field, boolean isExcluded) {
        if (!this.breakTypeInfoMap.containsKey(field)) {
            this.breakTypeInfoMap.put(field, new SimpleBreakTypeInfo(field));
        }

        if (isExcluded) {
            this.breakTypeInfoMap.get(field).addBreakExclude();
        } else {
            this.breakTypeInfoMap.get(field).addBreak();
        }
    }

    public List getBreakTypeInfo() {
        List breakTypeInfoList = new ArrayList(this.breakTypeInfoMap.values());
        Collections.sort(breakTypeInfoList);
        return breakTypeInfoList;
    }

    public int getIncludedBreakSize() {
        return this.includedBreakSize;
    }

    public int getExcludedBreakSize() {
        return this.excludedBreakSize;
    }

    public boolean hasGroupBreaks() {
        return this.hasGroupBreaks;
    }

    public Set getLeftFields() {
        return this.leftFields;
    }

    public Set getRightFields() {
        return this.rightFields;
    }

    public Set getFieldBreakFields() {
        return this.fieldBreakFields;
    }

    public Set getIncludedFieldBreakFields() {
        return this.includedFieldBreakFields;
    }

    public Set getExcludedFieldBreakFields() {
        return this.excludedFieldBreakFields;
    }

    public Set getGroupBreakFields() {
        return this.groupBreakFields;
    }

    public static class SimpleBreakTypeInfo implements BreakTypeInfo {

        private String type;
        private int breakCount;
        private int excludeCount;

        SimpleBreakTypeInfo(String type) {
            this.type = type;
            this.breakCount = 0;
            this.excludeCount = 0;
        }

        public String getType() {
            return this.type;
        }

        public void setType(String type) {
            this.type = type;
        }

        public int getBreakCount() {
            return this.breakCount;
        }

        void addBreak() {
            this.breakCount++;
        }

        public int getExcludeCount() {
            return this.excludeCount;
        }

        void addBreakExclude() {
            this.excludeCount++;
        }

        public int compareTo(BreakTypeInfo other) {
            if (this.breakCount < other.getBreakCount()) {
                return 1;
            } else if (this.breakCount > other.getBreakCount()) {
                return -1;
            } else if (this.excludeCount < other.getExcludeCount()) {
                return 1;
            } else if (this.excludeCount > other.getExcludeCount()) {
                return -1;
            } else {
                return 0;
            }
        }

        @Override
        public boolean equals(Object o) {
            if (this == o) {
                return true;
            }
            if (!(o instanceof SimpleBreakTypeInfo)) {
                return false;
            }

            SimpleBreakTypeInfo that = (SimpleBreakTypeInfo) o;

            if (breakCount != that.breakCount) {
                return false;
            }
            if (excludeCount != that.excludeCount) {
                return false;
            }
            return !(type != null ? !type.equals(that.type) : that.type != null);
        }

        @Override
        public int hashCode() {
            int result = type != null ? type.hashCode() : 0;
            result = 31 * result + breakCount;
            result = 31 * result + excludeCount;
            return result;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy