/* * Copyright 2015 Red Hat, Inc. and/or its affiliates. * * 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 org.drools.workbench.services.verifier.core.checks; import java.util.Collections; import java.util.Optional; import org.drools.workbench.services.verifier.api.client.configuration.AnalyzerConfiguration; import org.drools.workbench.services.verifier.api.client.index.Field; import org.drools.workbench.services.verifier.api.client.relations.Conflict; import org.drools.workbench.services.verifier.api.client.reporting.CheckType; import org.drools.workbench.services.verifier.api.client.reporting.ImpossibleMatchIssue; import org.drools.workbench.services.verifier.api.client.reporting.Issue; import org.drools.workbench.services.verifier.api.client.reporting.Severity; import org.drools.workbench.services.verifier.core.cache.inspectors.PatternInspector; import org.drools.workbench.services.verifier.core.cache.inspectors.RuleInspector; import org.drools.workbench.services.verifier.core.cache.inspectors.condition.ComparableConditionInspector; import org.drools.workbench.services.verifier.core.cache.inspectors.condition.ConditionsInspectorMultiMap; import org.drools.workbench.services.verifier.core.checks.base.SingleCheck; import static org.drools.workbench.services.verifier.api.client.relations.HumanReadable.toHumanReadableString; public class DetectImpossibleMatchCheck extends SingleCheck { private Conflict conflict = Conflict.EMPTY; public DetectImpossibleMatchCheck(final RuleInspector ruleInspector, final AnalyzerConfiguration configuration) { super(ruleInspector, configuration, CheckType.IMPOSSIBLE_MATCH); } @Override public boolean check() { conflict = ruleInspector.getPatternsInspector().stream() .map( PatternInspector::getConditionsInspector ) .map( ConditionsInspectorMultiMap::hasConflicts ) .filter(Conflict::foundIssue ) .findFirst() .orElse( Conflict.EMPTY ); return hasIssues = conflict != Conflict.EMPTY; } @Override protected Severity getDefaultSeverity() { return Severity.ERROR; } @Override protected Issue makeIssue(final Severity severity, final CheckType checkType) { return new ImpossibleMatchIssue(severity, checkType, Integer.toString(ruleInspector.getRowIndex() + 1), getFactType(), getFieldName(), toHumanReadableString(conflict.getOrigin() .getConflictedItem()), toHumanReadableString(conflict.getOrigin() .getConflictingItem()), Collections.singleton(ruleInspector.getRowIndex() + 1)); } private String getFieldName() { final Optional<Field> field = getField(); if (field.isPresent()) { return field.get().getName(); } else { return ""; } } private String getFactType() { final Optional<Field> field = getField(); if (field.isPresent()) { return field.get().getFactType(); } else { return ""; } } private Optional<Field> getField() { if (conflict.getOrigin() .getConflictedItem() instanceof ComparableConditionInspector) { final Field field = ((ComparableConditionInspector) conflict.getOrigin() .getConflictedItem()).getField(); return Optional.of(field); } else { return Optional.empty(); } } }