Search in sources :

Example 6 with Rule

use of org.drools.impact.analysis.model.Rule in project drools by kiegroup.

the class ModelToGraphConverter method processInsert.

private void processInsert(GraphAnalysis graphAnalysis, String pkgName, String ruleName, InsertAction action) {
    Node source = graphAnalysis.getNode(fqdn(pkgName, ruleName));
    Class<?> insertedClass = action.getActionClass();
    if (!graphAnalysis.isRegisteredClass(insertedClass)) {
        // Not likely happen but not invalid
        logger.warn("Not found {} in reactiveMap", insertedClass);
        return;
    }
    // property based link
    List<InsertedProperty> insertedProperties = action.getInsertedProperties();
    for (InsertedProperty insertedProperty : insertedProperties) {
        String property = insertedProperty.getProperty();
        for (AnalyzedRule reactedRule : graphAnalysis.getRulesReactiveTo(insertedClass, property)) {
            List<Pattern> patterns = reactedRule.getRule().getLhs().getPatterns().stream().filter(pattern -> pattern.getPatternClass() == insertedClass).collect(Collectors.toList());
            for (Pattern pattern : patterns) {
                List<Constraint> constraints = pattern.getConstraints().stream().filter(constraint -> constraint.getProperty() != null && constraint.getProperty().equals(property)).collect(Collectors.toList());
                ReactivityType combinedLinkType = ReactivityType.UNKNOWN;
                if (constraints.isEmpty()) {
                    // This rule is reactive to the property but cannot find its constraint (e.g. [age > $a] non-literal constraint). It means UNKNOWN impact
                    combinedLinkType = ReactivityType.UNKNOWN;
                } else {
                    // If constraints contain at least one POSITIVE, we consider it's POSITIVE.
                    for (Constraint constraint : constraints) {
                        ReactivityType linkType = linkType(constraint, insertedProperty);
                        if (linkType == ReactivityType.POSITIVE) {
                            combinedLinkType = ReactivityType.POSITIVE;
                            break;
                        } else if (linkType == ReactivityType.NEGATIVE) {
                            // NEGATIVE is stronger than UNKNOWN (but may be configurable)
                            combinedLinkType = ReactivityType.NEGATIVE;
                        } else if (combinedLinkType == ReactivityType.NEGATIVE && linkType == ReactivityType.UNKNOWN) {
                        // Don't overwrite with UNKNOWN
                        } else {
                            // UNKNOWN
                            combinedLinkType = linkType;
                        }
                    }
                }
                if (combinedLinkType == ReactivityType.NEGATIVE) {
                    // TODO: handle "exists" case
                    continue;
                }
                if (combinedLinkType == ReactivityType.POSITIVE && !pattern.isPositive()) {
                    // POSITIVE insert in not() means NEGATIVE
                    combinedLinkType = combinedLinkType.negate();
                }
                Node target = graphAnalysis.getNode(fqdn(pkgName, reactedRule.getRule().getName()));
                linkNodesIfExpected(source, target, combinedLinkType);
            }
        }
    }
    // class based link
    for (AnalyzedRule reactedRule : graphAnalysis.getRulesReactiveToWithoutProperty(insertedClass)) {
        Node target = graphAnalysis.getNode(fqdn(pkgName, reactedRule.getRule().getName()));
        linkNodesIfExpected(source, target, reactedRule.getReactivityType());
    }
}
Also used : LeftHandSide(org.drools.impact.analysis.model.left.LeftHandSide) Logger(org.slf4j.Logger) Collection(java.util.Collection) LoggerFactory(org.slf4j.LoggerFactory) AnalysisModel(org.drools.impact.analysis.model.AnalysisModel) ModifiedMapProperty(org.drools.impact.analysis.model.right.ModifiedMapProperty) Collectors(java.util.stream.Collectors) Pattern(org.drools.impact.analysis.model.left.Pattern) InsertedProperty(org.drools.impact.analysis.model.right.InsertedProperty) ModifyAction(org.drools.impact.analysis.model.right.ModifyAction) List(java.util.List) InsertAction(org.drools.impact.analysis.model.right.InsertAction) ModifiedProperty(org.drools.impact.analysis.model.right.ModifiedProperty) Rule(org.drools.impact.analysis.model.Rule) RightHandSide(org.drools.impact.analysis.model.right.RightHandSide) MapConstraint(org.drools.impact.analysis.model.left.MapConstraint) ConsequenceAction(org.drools.impact.analysis.model.right.ConsequenceAction) Package(org.drools.impact.analysis.model.Package) Constraint(org.drools.impact.analysis.model.left.Constraint) InsertedProperty(org.drools.impact.analysis.model.right.InsertedProperty) Pattern(org.drools.impact.analysis.model.left.Pattern) MapConstraint(org.drools.impact.analysis.model.left.MapConstraint) Constraint(org.drools.impact.analysis.model.left.Constraint)

Example 7 with Rule

use of org.drools.impact.analysis.model.Rule in project drools by kiegroup.

the class GraphvizOutputTest method testSimpleGraph.

@Test
public void testSimpleGraph() {
    Node node1 = new Node(new Rule("org.example", "rule1", "dummy"));
    Node node2 = new Node(new Rule("org.example", "rule2", "dummy"));
    Node node3 = new Node(new Rule("org.example", "rule3", "dummy"));
    Node node4 = new Node(new Rule("org.example", "rule4", "dummy"));
    Node node5 = new Node(new Rule("org.example", "rule5", "dummy"));
    Node.linkNodes(node1, node2, ReactivityType.POSITIVE);
    Node.linkNodes(node1, node3, ReactivityType.NEGATIVE);
    Node.linkNodes(node2, node4, ReactivityType.UNKNOWN);
    Node.linkNodes(node3, node5, ReactivityType.POSITIVE);
    Map<String, Node> nodeMap = new HashMap<>();
    nodeMap.put(node1.getFqdn(), node1);
    nodeMap.put(node2.getFqdn(), node2);
    nodeMap.put(node3.getFqdn(), node3);
    nodeMap.put(node4.getFqdn(), node4);
    nodeMap.put(node5.getFqdn(), node5);
    Graph graph = new Graph(nodeMap);
    GraphImageGenerator generator = new GraphImageGenerator("simple");
    generator.generateDot(graph);
    generator.generateSvg(graph);
    generator.generatePng(graph);
}
Also used : Graph(org.drools.impact.analysis.graph.Graph) HashMap(java.util.HashMap) Node(org.drools.impact.analysis.graph.Node) Rule(org.drools.impact.analysis.model.Rule) Test(org.junit.Test)

Aggregations

Rule (org.drools.impact.analysis.model.Rule)7 Package (org.drools.impact.analysis.model.Package)4 ConsequenceAction (org.drools.impact.analysis.model.right.ConsequenceAction)4 List (java.util.List)3 Collectors (java.util.stream.Collectors)3 LeftHandSide (org.drools.impact.analysis.model.left.LeftHandSide)3 Pattern (org.drools.impact.analysis.model.left.Pattern)3 InsertAction (org.drools.impact.analysis.model.right.InsertAction)3 InsertedProperty (org.drools.impact.analysis.model.right.InsertedProperty)3 ModifiedMapProperty (org.drools.impact.analysis.model.right.ModifiedMapProperty)3 ModifiedProperty (org.drools.impact.analysis.model.right.ModifiedProperty)3 ModifyAction (org.drools.impact.analysis.model.right.ModifyAction)3 RightHandSide (org.drools.impact.analysis.model.right.RightHandSide)3 Collection (java.util.Collection)2 AnalysisModel (org.drools.impact.analysis.model.AnalysisModel)2 Constraint (org.drools.impact.analysis.model.left.Constraint)2 MapConstraint (org.drools.impact.analysis.model.left.MapConstraint)2 RuleContext (org.drools.modelcompiler.builder.generator.RuleContext)2 Logger (org.slf4j.Logger)2 LoggerFactory (org.slf4j.LoggerFactory)2