org.drools.verifier.redundancy.Warnings.drl Maven / Gradle / Ivy
/*
* Copyright 2010 JBoss Inc
*
* 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.
*/
//created on: 9.12.2007
package org.drools.verifier.redundancy
//list any import classes here.
global VerifierReport result;
//declare any global variables here
import java.util.Collection;
import java.util.ArrayList;
import org.drools.verifier.components.SubRule;
import org.drools.verifier.components.VerifierRule;
import org.drools.verifier.components.Consequence;
import org.drools.verifier.data.VerifierReport;
import org.drools.verifier.components.RuleComponent;
import org.drools.verifier.report.components.Redundancy;
import org.drools.verifier.report.components.Equivalence;
import org.drools.verifier.report.components.Subsumption;
import org.drools.verifier.report.components.VerifierMessage;
import org.drools.verifier.report.components.Cause;
import org.drools.verifier.report.components.Severity;
import org.drools.verifier.report.components.MessageType;
import java.util.Map;
import java.util.HashMap;
rule "Find redundant LHS"
@verifying_scopes(["knowledge-package", "decision-table"])
when
# Check that VerifierRule $left and $right have redundant fields.
$left :VerifierRule()
$right :VerifierRule(
path != $left.path
)
$leftSubRules : ArrayList()
from collect(
SubRule(
rulePath == $left.path
)
)
$rightSubRules : ArrayList()
from collect(
SubRule(
rulePath == $right.path
)
)
forall (
$subRule :SubRule(
) from $leftSubRules
Subsumption(
left == $subRule,
right memberOf $rightSubRules
)
)
forall (
$subRule :SubRule(
) from $rightSubRules
Subsumption(
left == $subRule,
right memberOf $leftSubRules
)
)
then
end
rule "Find equivalent Rules" extends "Find redundant LHS"
# This rule needs to fire after "Find redundant rules"
# or the not Reduncancy( ... ) does not check correctly.
salience -1
when
not Equivalence(
items contains $left,
items contains $right
)
# RHS should not be redundant
$leftConsequence : Consequence(
path == $left.consequencePath,
consequenceType == $left.consequenceType
)
$rightConsequence : Consequence(
path == $right.consequencePath,
consequenceType == $right.consequenceType
)
not Redundancy(
items contains $leftConsequence,
items contains $rightConsequence
)
$causes : ArrayList()
from collect(
Subsumption(
left memberOf $rightSubRules,
right memberOf $leftSubRules
)
)
then
Map impactedRules = new HashMap();
impactedRules.put( $leftConsequence.getRulePath(), $leftConsequence.getRuleName());
impactedRules.put( $rightConsequence.getRulePath(), $rightConsequence.getRuleName());
Equivalence equivalence = new Equivalence( $left, $right, $causes );
insert( equivalence );
result.add(new VerifierMessage(
impactedRules,
Severity.WARNING,
MessageType.EQUIVALANCE,
null,
"Rule is equivalent to rule " + $right.getName() + ".",
equivalence ) );
end
//
// Dependencies:
//
// Needs at least one rule from these packages:
// package org.drools.verifier.equivalency.rules
// rule "Find equivalent Rules"
// package org.drools.verifier.redundancy.rules
// rule "Find redundant Rules, strong redundancy"
//
// And this rule:
// package org.drools.verifier.redundancy.possibilities
// rule "Find rule possibility redundancy"
//
rule "Find redundant rules" extends "Find redundant LHS"
when
not Redundancy(
items contains $left,
items contains $right
)
# RHS needs to be redundant
$leftConsequence : Consequence(
path == $left.consequencePath,
consequenceType == $left.consequenceType
)
$rightConsequence : Consequence(
path == $right.consequencePath,
consequenceType == $right.consequenceType
)
exists Redundancy(
items contains $leftConsequence,
items contains $rightConsequence
)
// $causes : ArrayList()
// from collect(
// Subsumption(
// (
// left memberOf $rightSubRules
// &&
// right memberOf $leftSubRules
// ) || (
// right memberOf $rightSubRules
// &&
// left memberOf $leftSubRules
// )
// )
// )
then
// Map impactedRules = new HashMap();
// impactedRules.put( $leftConsequence.getRulePath(), $leftConsequence.getRuleName());
// impactedRules.put( $rightConsequence.getRulePath(), $rightConsequence.getRuleName());
// Redundancy redundancy = new Redundancy( $left, $right, $causes );
// insert( redundancy );
// result.add(new VerifierMessage(
// impactedRules,
// Severity.WARNING,
// MessageType.REDUNDANCY,
// null,
// "Rules " + $right.getName() + " and " + $left.getName() + " are redundant.",
// redundancy ) );
end
/*
//
// Dependencies:
//
// Needs at least one rule from these packages:
// package org.drools.verifier.equivalency.rules
// rule "Find equivalent Rules"
// package org.drools.verifier.redundancy.rules
// rule "Find redundant Rules, strong redundancy"
//
// And this rule:
// package org.drools.verifier.redundancy.possibilities
// rule "Find rule possibility redundancy"
//
rule "Find subsumptant rule possibilities from different rules"
@verifying_scopes(["knowledge-package", "decision-table"])
salience -100
when
$left :VerifierRule()
$right :VerifierRule(
path != $left.path
)
$subsumption :Subsumption(
left == $left,
right == $right
)
# No redundacy
not Subsumption(
left == $subsumption.right,
right == $subsumption.left
)
then
Map impactedRules = new HashMap();
impactedRules.put( $left.getPath(), $left.getName());
impactedRules.put( $right.getPath(), $right.getName());
Collection causes = new ArrayList();
causes.add( $subsumption );
result.add(new VerifierMessage(
impactedRules,
Severity.WARNING,
MessageType.SUBSUMPTION,
null,
"Rules are subsumptant.",
causes ) );
end
*/
© 2015 - 2025 Weber Informatics LLC | Privacy Policy