diff --git a/drools-base/src/main/java/org/drools/base/rule/accessor/DeclarationScopeResolver.java b/drools-base/src/main/java/org/drools/base/rule/accessor/DeclarationScopeResolver.java index 7bd22b64cbf..5bfaf9b0cc7 100644 --- a/drools-base/src/main/java/org/drools/base/rule/accessor/DeclarationScopeResolver.java +++ b/drools-base/src/main/java/org/drools/base/rule/accessor/DeclarationScopeResolver.java @@ -109,7 +109,7 @@ private Map getAllExtendedDeclaration(RuleImpl rule, Map iterator = buildList.descendingIterator(); iterator.hasNext();) { + for (final Iterator iterator = buildList.iterator(); iterator.hasNext();) { final Declaration declaration = iterator.next().resolveDeclaration( identifier ); if ( declaration != null ) { return declaration; diff --git a/drools-beliefs/pom.xml b/drools-beliefs/pom.xml index d3e31fc78f1..cfd1cbaefb8 100644 --- a/drools-beliefs/pom.xml +++ b/drools-beliefs/pom.xml @@ -95,10 +95,10 @@ test - junit - junit + org.junit.jupiter + junit-jupiter test - + org.assertj assertj-core diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/BayesAbsorbtionTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/BayesAbsorbtionTest.java index 07c5a481ddf..e2a8cd601f5 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/BayesAbsorbtionTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/BayesAbsorbtionTest.java @@ -20,15 +20,16 @@ import org.drools.beliefs.graph.Graph; import org.drools.beliefs.graph.GraphNode; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.util.Arrays; +import static org.assertj.core.api.Assertions.assertThat; import static org.drools.beliefs.bayes.GraphTest.addNode; import static org.drools.beliefs.bayes.GraphTest.bitSet; -import static org.drools.beliefs.bayes.JunctionTreeTest.assertArray; import static org.drools.beliefs.bayes.JunctionTreeTest.scaleDouble; + public class BayesAbsorbtionTest { @Test @@ -37,7 +38,7 @@ public void testDivide1() { double[] oldD = new double[] { 2, 4, 1 }; double[] r = BayesAbsorption.dividePotentials(newD, oldD); - assertArray(new double[]{5, 2, 4}, scaleDouble(3, r)); + assertThat(scaleDouble(3, r)).containsExactly(5, 2, 4); } @Test @@ -46,7 +47,7 @@ public void testDivide2() { double[] oldD = new double[] { 0.1, 0.2, 0.3, 0.4 }; double[] r = BayesAbsorption.dividePotentials(newD, oldD); - assertArray(new double[]{5.0, 5.0, 5.0, 5.0}, scaleDouble(3, r)); + assertThat(scaleDouble(3, r)).containsExactly(5.0, 5.0, 5.0, 5.0); } @Test @@ -94,7 +95,7 @@ public void testAbsorption1() { BayesAbsorption p = new BayesAbsorption(sepVarPos, oldSepPotentials, sep.getPotentials(), sepVarMultipliers, vars, node1.getPotentials()); p.absorb(); - assertArray(new double[]{0.035, 0.135, 0.3, 0.529}, scaleDouble(3, node1.getPotentials())); + assertThat(scaleDouble(3, node1.getPotentials())).containsExactly(0.035, 0.135, 0.3, 0.529); } @Test @@ -145,7 +146,7 @@ public void testAbsorption2() { BayesAbsorption p = new BayesAbsorption(sepVarPos, oldSepPotentials, sep.getPotentials(), sepVarMultipliers, vars, node1.getPotentials()); p.absorb(); - assertArray(new double[]{ 0.01, 0.019, 0.055, 0.073, 0.137, 0.163, 0.254, 0.289 }, scaleDouble(3, node1.getPotentials())); + assertThat(scaleDouble(3, node1.getPotentials())).containsExactly(0.01, 0.019, 0.055, 0.073, 0.137, 0.163, 0.254, 0.289); } @Test @@ -197,6 +198,6 @@ public void testAbsorption3() { BayesAbsorption p = new BayesAbsorption(sepVarPos, oldSepPotentials, sep.getPotentials(), sepVarMultipliers, vars, node1.getPotentials()); p.absorb(); - assertArray(new double[]{0.01, 0.038, 0.028, 0.075, 0.139, 0.222, 0.194, 0.295}, scaleDouble(3, node1.getPotentials())); + assertThat(scaleDouble(3, node1.getPotentials())).containsExactly(0.01, 0.038, 0.028, 0.075, 0.139, 0.222, 0.194, 0.295); } } \ No newline at end of file diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/BayesProjectionTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/BayesProjectionTest.java index bb6aabcacea..2d72957bb91 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/BayesProjectionTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/BayesProjectionTest.java @@ -20,11 +20,11 @@ import org.drools.beliefs.graph.Graph; import org.drools.beliefs.graph.GraphNode; -import org.junit.Test; +import org.junit.jupiter.api.Test; +import static org.assertj.core.api.Assertions.assertThat; import static org.drools.beliefs.bayes.GraphTest.addNode; import static org.drools.beliefs.bayes.GraphTest.bitSet; -import static org.drools.beliefs.bayes.JunctionTreeTest.assertArray; import static org.drools.beliefs.bayes.JunctionTreeTest.scaleDouble; public class BayesProjectionTest { @@ -66,7 +66,7 @@ public void testProjection1() { BayesProjection p = new BayesProjection(vars, node1.getPotentials(), sepVarPos, sepVarMultipliers, projectedSepPotentials); p.project(); - assertArray(new double[]{0.1, 0.2, 0.3, 0.4}, scaleDouble(3, projectedSepPotentials)); + assertThat(scaleDouble(3, projectedSepPotentials)).containsExactly(0.1, 0.2, 0.3, 0.4); } @Test @@ -110,7 +110,7 @@ public void testProjection2() { p.project(); // remember it's been normalized, from 0.3, 0.7, 1.1, 1.5 - assertArray(new double[]{0.083, 0.194, 0.306, 0.417}, scaleDouble(3, projectedSepPotentials)); + assertThat(scaleDouble(3, projectedSepPotentials)).containsExactly(0.083, 0.194, 0.306, 0.417); } @Test @@ -156,7 +156,7 @@ public void testProjection3() { p.project(); // remember it's been normalized, from 0.4, 0.6, 1.2, 1.4 - assertArray(new double[]{0.111, 0.167, 0.333, 0.389}, scaleDouble(3, projectedSepPotentials)); + assertThat(scaleDouble(3, projectedSepPotentials)).containsExactly(0.111, 0.167, 0.333, 0.389); } @Test @@ -202,7 +202,7 @@ public void testProjection4() { p.project(); // remember it's been normalized, from 0.6 0.8 1.0 1.2 - assertArray(new double[]{0.167, 0.222, 0.278, 0.333}, scaleDouble(3, projectedSepPotentials)); + assertThat(scaleDouble(3, projectedSepPotentials)).containsExactly(0.167, 0.222, 0.278, 0.333); } } \ No newline at end of file diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/GlobalUpdateTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/GlobalUpdateTest.java index 3955b007eca..a60859989e8 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/GlobalUpdateTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/GlobalUpdateTest.java @@ -20,11 +20,10 @@ import org.drools.beliefs.graph.Graph; import org.drools.beliefs.graph.GraphNode; -import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; import java.util.ArrayList; -import java.util.Arrays; import java.util.List; import static org.assertj.core.api.Assertions.assertThat; @@ -63,7 +62,7 @@ public class GlobalUpdateTest { final List messageResults = new ArrayList(); final List globalUpdateResults = new ArrayList(); - @Before + @BeforeEach public void startUp() { int i = 0; List list = new ArrayList(); @@ -111,92 +110,92 @@ public void afterGlobalUpdate(CliqueState clique) { @Test public void testCollectFromRootClique() { bayesInstance.collectEvidence(n0); - assertThat(messageResults).isEqualTo(asList("3:2", "4:2", "2:1", "7:6", "8:6", "6:5", "5:1", "1:0")); + assertThat(messageResults).containsExactly("3:2", "4:2", "2:1", "7:6", "8:6", "6:5", "5:1", "1:0"); } @Test public void testCollectFromMidTipClique() { bayesInstance.collectEvidence(n4); - assertThat(messageResults).isEqualTo(asList("0:1", "7:6", "8:6", "6:5", "5:1", "1:2", "3:2", "2:4")); + assertThat(messageResults).containsExactly("0:1", "7:6", "8:6", "6:5", "5:1", "1:2", "3:2", "2:4"); } @Test public void testCollectFromEndTipClique() { bayesInstance.collectEvidence(n7); - assertThat(messageResults).isEqualTo(asList("0:1", "3:2", "4:2", "2:1", "1:5", "5:6", "8:6", "6:7")); + assertThat(messageResults).containsExactly("0:1", "3:2", "4:2", "2:1", "1:5", "5:6", "8:6", "6:7"); } @Test public void testCollectFromMidClique() { bayesInstance.collectEvidence(n5); - assertThat(messageResults).isEqualTo(asList("0:1", "3:2", "4:2", "2:1", "1:5", "7:6", "8:6", "6:5")); + assertThat(messageResults).containsExactly("0:1", "3:2", "4:2", "2:1", "1:5", "7:6", "8:6", "6:5"); } @Test public void testDistributeFromRootClique() { bayesInstance.distributeEvidence(n0); - assertThat(messageResults).isEqualTo(asList("0:1", "1:2", "2:3", "2:4", "1:5", "5:6", "6:7", "6:8")); + assertThat(messageResults).containsExactly("0:1", "1:2", "2:3", "2:4", "1:5", "5:6", "6:7", "6:8"); } @Test public void testDistributeFromMidTipClique() { bayesInstance.distributeEvidence(n4); - assertThat(messageResults).isEqualTo(asList("4:2", "2:1", "1:0", "1:5", "5:6", "6:7", "6:8", "2:3")); + assertThat(messageResults).containsExactly("4:2", "2:1", "1:0", "1:5", "5:6", "6:7", "6:8", "2:3"); } @Test public void testDistributeFromEndTipClique() { bayesInstance.distributeEvidence(n7); - assertThat(messageResults).isEqualTo(asList("7:6", "6:5", "5:1", "1:0", "1:2", "2:3", "2:4", "6:8")); + assertThat(messageResults).containsExactly("7:6", "6:5", "5:1", "1:0", "1:2", "2:3", "2:4", "6:8"); } @Test public void testDistributeFromMidClique() { bayesInstance.distributeEvidence(n5); - assertThat(messageResults).isEqualTo(asList("5:1", "1:0", "1:2", "2:3", "2:4", "5:6", "6:7", "6:8")); + assertThat(messageResults).containsExactly("5:1", "1:0", "1:2", "2:3", "2:4", "5:6", "6:7", "6:8"); } @Test public void testGlobalUpdateFromRootClique() { bayesInstance.globalUpdate(n0); - assertThat(messageResults).isEqualTo(asList("3:2", "4:2", "2:1", "7:6", "8:6", "6:5", "5:1", "1:0", //n0 + assertThat(messageResults).containsExactly("3:2", "4:2", "2:1", "7:6", "8:6", "6:5", "5:1", "1:0", //n0 "0:1", "1:2", "2:3", "2:4", "1:5", "5:6", "6:7", "6:8" //n0 - )); - assertThat(globalUpdateResults).isEqualTo(asList("0")); + ); + assertThat(globalUpdateResults).containsExactly("0"); } @Test public void testGlobalUpdateFromMidTipClique() { bayesInstance.globalUpdate(n4); - assertThat(messageResults).isEqualTo(asList("0:1", "7:6", "8:6", "6:5", "5:1", "1:2", "3:2", "2:4", //n4 + assertThat(messageResults).containsExactly("0:1", "7:6", "8:6", "6:5", "5:1", "1:2", "3:2", "2:4", //n4 "4:2", "2:1", "1:0", "1:5", "5:6", "6:7", "6:8", "2:3" //n4 - )); - assertThat(globalUpdateResults).isEqualTo(asList("4")); + ); + assertThat(globalUpdateResults).containsExactly("4"); } @Test public void testGlobalUpdateFromEndTipClique() { bayesInstance.globalUpdate(n7); - assertThat(messageResults).isEqualTo(asList("0:1", "3:2", "4:2", "2:1", "1:5", "5:6", "8:6", "6:7", //n7 + assertThat(messageResults).containsExactly("0:1", "3:2", "4:2", "2:1", "1:5", "5:6", "8:6", "6:7", //n7 "7:6", "6:5", "5:1", "1:0", "1:2", "2:3", "2:4", "6:8" //n7 - )); - assertThat(globalUpdateResults).isEqualTo(asList("7")); + ); + assertThat(globalUpdateResults).containsExactly("7"); } @Test public void testGlobalUpdateFromMidClique() { bayesInstance.globalUpdate(n5); - assertThat(messageResults).isEqualTo(asList("0:1", "3:2", "4:2", "2:1", "1:5", "7:6", "8:6", "6:5", //n5 + assertThat(messageResults).containsExactly("0:1", "3:2", "4:2", "2:1", "1:5", "7:6", "8:6", "6:5", //n5 "5:1", "1:0", "1:2", "2:3", "2:4", "5:6", "6:7", "6:8" //n5 - )); - assertThat(globalUpdateResults).isEqualTo(asList("5")); + ); + assertThat(globalUpdateResults).containsExactly("5"); } @Test public void testDistributeFromGlobalUpdate() { bayesInstance.globalUpdate(); - assertThat(messageResults).isEqualTo(asList("3:2", "4:2", "2:1", "7:6", "8:6", "6:5", "5:1", "1:0", //n0 + assertThat(messageResults).containsExactly("3:2", "4:2", "2:1", "7:6", "8:6", "6:5", "5:1", "1:0", //n0 "0:1", "1:2", "2:3", "2:4", "1:5", "5:6", "6:7", "6:8" //n0 // "0:1", "3:2", "4:2", "2:1", "7:6", "8:6", "6:5", "5:1", //n1 // "1:0", "1:2", "2:3", "2:4", "1:5", "5:6", "6:7", "6:8", //n1 @@ -214,18 +213,9 @@ public void testDistributeFromGlobalUpdate() { // "7:6", "6:5", "5:1", "1:0", "1:2", "2:3", "2:4", "6:8", //n7 // "0:1", "3:2", "4:2", "2:1", "1:5", "5:6", "7:6", "6:8", //n8 // "8:6", "6:5", "5:1", "1:0", "1:2", "2:3", "2:4", "6:7" //n8 - )); + ); -// assertEquals( asList( "0", "1", "2", "3", "4", "5", "6", "7", "8"), globalUpdateResults); - assertThat(globalUpdateResults).isEqualTo(asList("0")); - } - - public void testGlobalUpdate() { - bayesInstance.globalUpdate(); - } - - public List asList(String... items) { - return Arrays.asList(items); + assertThat(globalUpdateResults).containsExactly("0"); } public void connectChildren(Graph graph, JunctionTreeClique parent, List list, JunctionTreeClique... children) { diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/GraphTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/GraphTest.java index 640b78a32a7..f844aec9655 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/GraphTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/GraphTest.java @@ -23,9 +23,7 @@ import org.drools.beliefs.graph.impl.EdgeImpl; import org.drools.util.bitmask.OpenBitSet; -import java.util.ArrayList; import java.util.Collection; -import java.util.List; import static org.assertj.core.api.Assertions.assertThat; @@ -56,11 +54,11 @@ public static boolean assertLinkedVertex(boolean[][] adjMatrix, int... ints) { int id = ints[0]; Collection adjVert = JunctionTreeBuilder.getAdjacentVertices(adjMatrix, id); - assertThat(adjVert.size()).isEqualTo(ints.length - 1); + assertThat(adjVert).hasSize(ints.length - 1); for ( int i = 1; i < ints.length; i++ ) { assertThat(adjMatrix[id][ints[i]]).as("link was not true " + id + ", " + i).isTrue(); assertThat(adjMatrix[ints[i]][id]).as("link was not true " + i + ", " + id).isTrue(); - assertThat(adjVert.contains(ints[i])).as("does not contain " + ints[i]).isTrue(); + assertThat(adjVert).as("does not contain " + ints[i]).contains(ints[i]); } return false; @@ -75,14 +73,6 @@ public static GraphNode addNode(Graph graph) { - public static List asList(int[] array) { - List list = new ArrayList(array.length); - for (int i = 0; i < array.length; i++) { - list.add(array[i]); - } - return list; - } - public static OpenBitSet bitSet(String s) { OpenBitSet bitSet = new OpenBitSet( ); bitSet.setBits(new long[] { Long.valueOf(s, 2) }); diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/JunctionTreeBuilderTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/JunctionTreeBuilderTest.java index 56fcb2675ac..a284033836a 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/JunctionTreeBuilderTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/JunctionTreeBuilderTest.java @@ -21,10 +21,9 @@ import org.drools.beliefs.graph.Graph; import org.drools.beliefs.graph.GraphNode; import org.drools.util.bitmask.OpenBitSet; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.util.ArrayList; -import java.util.Arrays; import java.util.Collections; import java.util.HashMap; import java.util.HashSet; @@ -187,8 +186,8 @@ public void testCreateClique() { boolean[][] clonedAdjMatrix = JunctionTreeBuilder.cloneAdjacencyMarix(jtBuilder.getAdjacencyMatrix()); jtBuilder.createClique(dX1.getId(), clonedAdjMatrix, vertices, adjList ); - assertThat(vertices.size()).isEqualTo(3); - assertThat(vertices.containsAll(Arrays.asList(2, 3, 4))).isTrue(); + assertThat(vertices).hasSize(3); + assertThat(vertices).containsExactly(2, 3, 4); assertLinkedNode(jtBuilder, 1, 2, 3, 4); assertLinkedNode(jtBuilder, 2, 1, 3, 4); @@ -204,18 +203,18 @@ public void testCliqueSuperSet() { List cliques = new ArrayList(); OpenBitSet OpenBitSet1 = bitSet("00011110"); jtBuilder.updateCliques(cliques, OpenBitSet1); - assertThat(cliques.size()).isEqualTo(1); + assertThat(cliques).hasSize(1); // ignore subset OpenBitSet OpenBitSet2 = bitSet("00000110"); jtBuilder.updateCliques(cliques, OpenBitSet2); - assertThat(cliques.size()).isEqualTo(1); + assertThat(cliques).hasSize(1); assertThat(cliques.get(0)).isEqualTo(OpenBitSet1); // add overlapping, as not a pure subset OpenBitSet OpenBitSet3 = bitSet("01000110"); jtBuilder.updateCliques(cliques, OpenBitSet3); - assertThat(cliques.size()).isEqualTo(2); + assertThat(cliques).hasSize(2); assertThat(cliques.get(0)).isEqualTo(OpenBitSet1); assertThat(cliques.get(1)).isEqualTo(OpenBitSet3); } @@ -288,7 +287,7 @@ public void testPriorityQueueWithMinimalNewEdges() { assertThat(id).isEqualTo(8); assertThat(v.getNewEdgesRequired()).isEqualTo(6); - assertThat(p.size()).isEqualTo(0); + assertThat(p).isEmpty(); } @Test @@ -363,7 +362,7 @@ public void testPriorityQueueWithMaximalCliqueWeight() { assertThat(id).isEqualTo(5); assertThat(v.getWeightRequired()).isEqualTo(81); - assertThat(p.size()).isEqualTo(0); + assertThat(p).isEmpty(); } @Test @@ -443,8 +442,8 @@ public void testIterativeEliminationUsingEdgeAndWeight() { Set verticesToUpdate = new HashSet(); boolean[] adjList = clonedAdjMatrix[ id ]; jtBuilder.createClique(5, clonedAdjMatrix, verticesToUpdate, adjList); - assertThat(verticesToUpdate.size()).isEqualTo(4); - assertThat(verticesToUpdate.containsAll(Arrays.asList(1, 3, 6))).isTrue(); + assertThat(verticesToUpdate).hasSize(4); + assertThat(verticesToUpdate).contains(1, 3, 6); jtBuilder.eliminateVertex(p, elmVertMap, clonedAdjMatrix, adjList, verticesToUpdate, v ); // assert all new edges @@ -477,8 +476,8 @@ public void testIterativeEliminationUsingEdgeAndWeight() { verticesToUpdate = new HashSet(); adjList = clonedAdjMatrix[ id ]; jtBuilder.createClique(4, clonedAdjMatrix, verticesToUpdate, adjList); - assertThat(verticesToUpdate.size()).isEqualTo(3); - assertThat(verticesToUpdate.containsAll(Arrays.asList(1, 2, 6))).isTrue(); // don't forget 3 and 5 were already eliminated + assertThat(verticesToUpdate).hasSize(3); + assertThat(verticesToUpdate).containsExactly(1, 2, 6); // don't forget 3 and 5 were already eliminated jtBuilder.eliminateVertex(p, elmVertMap, clonedAdjMatrix, adjList, verticesToUpdate, v ); // assert all new edges @@ -518,7 +517,7 @@ public void testIterativeEliminationUsingEdgeAndWeight() { jtBuilder.createClique(6, clonedAdjMatrix, verticesToUpdate, adjList); jtBuilder.eliminateVertex(p, elmVertMap, clonedAdjMatrix, adjList, verticesToUpdate, v ); - assertThat(p.size()).isEqualTo(0); + assertThat(p).isEmpty(); } @Test @@ -611,11 +610,11 @@ public void testTriangulate2() { assertLinkedVertex(jtBuilder.getAdjacencyMatrix(), 5, 2, 3, 6); assertLinkedVertex(jtBuilder.getAdjacencyMatrix(), 6, 2, 5); - assertThat(cliques.size()).isEqualTo(5); // 5th is 0, which is just a dummy V to get numbers aligned - assertThat(cliques.contains(bitSet("1110"))).isTrue(); // x1, x2, x3 //a, b, c - assertThat(cliques.contains(bitSet("10100"))).isTrue(); // x2, x4 - assertThat(cliques.contains(bitSet("1100100"))).isTrue(); // x2, x5, x6 - assertThat(cliques.contains(bitSet("101100"))).isTrue(); // x2, x3, x5 + assertThat(cliques).hasSize(5); // 5th is 0, which is just a dummy V to get numbers aligned + assertThat(cliques).contains(bitSet("1110")); // x1, x2, x3 //a, b, c + assertThat(cliques).contains(bitSet("10100")); // x2, x4 + assertThat(cliques).contains(bitSet("1100100")); // x2, x5, x6 + assertThat(cliques).contains(bitSet("101100")); // x2, x3, x5 } @Test @@ -805,7 +804,7 @@ public void testJunctionTreeNoPruning() { assertThat(jtNode.getBitSet()).isEqualTo(OpenBitSet1); - assertThat(jtNode.getChildren().size()).isEqualTo(1); + assertThat(jtNode.getChildren()).hasSize(1); JunctionTreeSeparator sep = jtNode.getChildren().get(0); assertThat(sep.getParent().getBitSet()).isEqualTo(OpenBitSet1); assertThat(sep.getChild().getBitSet()).isEqualTo(OpenBitSet2); @@ -813,7 +812,7 @@ public void testJunctionTreeNoPruning() { jtNode = sep.getChild(); assertThat(jtNode.getBitSet()).isEqualTo(OpenBitSet2); - assertThat(jtNode.getChildren().size()).isEqualTo(1); + assertThat(jtNode.getChildren()).hasSize(1); sep = jtNode.getChildren().get(0); assertThat(sep.getParent().getBitSet()).isEqualTo(OpenBitSet2); assertThat(sep.getChild().getBitSet()).isEqualTo(OpenBitSet3); @@ -853,16 +852,16 @@ public void testJunctionWithPruning1() { assertThat(jtNode.getBitSet()).isEqualTo(OpenBitSet1); - assertThat(jtNode.getChildren().size()).isEqualTo(2); + assertThat(jtNode.getChildren()).hasSize(2); JunctionTreeSeparator sep = jtNode.getChildren().get(0); assertThat(sep.getParent().getBitSet()).isEqualTo(OpenBitSet1); assertThat(sep.getChild().getBitSet()).isEqualTo(OpenBitSet2); - assertThat(sep.getChild().getChildren().size()).isEqualTo(0); + assertThat(sep.getChild().getChildren()).isEmpty(); sep = jtNode.getChildren().get(1); assertThat(sep.getParent().getBitSet()).isEqualTo(OpenBitSet1); assertThat(sep.getChild().getBitSet()).isEqualTo(OpenBitSet3); - assertThat(sep.getChild().getChildren().size()).isEqualTo(0); + assertThat(sep.getChild().getChildren()).isEmpty(); } @@ -904,26 +903,26 @@ public void testJunctionWithPruning2() { assertThat(root.getBitSet()).isEqualTo(OpenBitSet1); - assertThat(root.getChildren().size()).isEqualTo(2); + assertThat(root.getChildren()).hasSize(2); JunctionTreeSeparator sep = root.getChildren().get(0); assertThat(sep.getParent().getBitSet()).isEqualTo(OpenBitSet1); assertThat(sep.getChild().getBitSet()).isEqualTo(OpenBitSet2); - assertThat(sep.getChild().getChildren().size()).isEqualTo(1); + assertThat(sep.getChild().getChildren()).hasSize(1); jtNode = sep.getChild(); assertThat(jtNode.getBitSet()).isEqualTo(OpenBitSet2); - assertThat(jtNode.getChildren().size()).isEqualTo(1); + assertThat(jtNode.getChildren()).hasSize(1); sep = jtNode.getChildren().get(0); assertThat(sep.getParent().getBitSet()).isEqualTo(OpenBitSet2); assertThat(sep.getChild().getBitSet()).isEqualTo(OpenBitSet3); assertThat(sep.getBitSet()).isEqualTo(intersect2And3); - assertThat(sep.getChild().getChildren().size()).isEqualTo(0); + assertThat(sep.getChild().getChildren()).isEmpty(); sep = root.getChildren().get(1); assertThat(sep.getParent().getBitSet()).isEqualTo(OpenBitSet1); assertThat(sep.getChild().getBitSet()).isEqualTo(OpenBitSet4); assertThat(sep.getBitSet()).isEqualTo(intersect1And4); - assertThat(sep.getChild().getChildren().size()).isEqualTo(0); + assertThat(sep.getChild().getChildren()).isEmpty(); } @Test @@ -966,26 +965,26 @@ public void testJunctionWithPruning3() { JunctionTreeClique root = jtNode; assertThat(root.getBitSet()).isEqualTo(OpenBitSet1); - assertThat(root.getChildren().size()).isEqualTo(2); + assertThat(root.getChildren()).hasSize(2); JunctionTreeSeparator sep = root.getChildren().get(0); assertThat(sep.getParent().getBitSet()).isEqualTo(OpenBitSet1); assertThat(sep.getChild().getBitSet()).isEqualTo(OpenBitSet2); - assertThat(sep.getChild().getChildren().size()).isEqualTo(0); + assertThat(sep.getChild().getChildren()).isEmpty(); sep = root.getChildren().get(1); assertThat(sep.getParent().getBitSet()).isEqualTo(OpenBitSet1); assertThat(sep.getChild().getBitSet()).isEqualTo(OpenBitSet4); assertThat(sep.getBitSet()).isEqualTo(intersect1And4); - assertThat(sep.getChild().getChildren().size()).isEqualTo(1); + assertThat(sep.getChild().getChildren()).hasSize(1); jtNode = sep.getChild(); assertThat(jtNode.getBitSet()).isEqualTo(OpenBitSet4); - assertThat(jtNode.getChildren().size()).isEqualTo(1); + assertThat(jtNode.getChildren()).hasSize(1); sep = jtNode.getChildren().get(0); assertThat(sep.getParent().getBitSet()).isEqualTo(OpenBitSet4); assertThat(sep.getChild().getBitSet()).isEqualTo(OpenBitSet3); assertThat(sep.getBitSet()).isEqualTo(intersect3And4); - assertThat(sep.getChild().getChildren().size()).isEqualTo(0); + assertThat(sep.getChild().getChildren()).isEmpty(); } @@ -1109,7 +1108,7 @@ public void testFullExample1() { JunctionTreeBuilder jtBuilder = new JunctionTreeBuilder( graph ); JunctionTreeClique root = jtBuilder.build(false).getRoot(); assertThat(root.getBitSet()).isEqualTo(clique1); - assertThat(root.getChildren().size()).isEqualTo(1); + assertThat(root.getChildren()).hasSize(1); // clique2 JunctionTreeSeparator sep = root.getChildren().get(0); @@ -1117,7 +1116,7 @@ public void testFullExample1() { JunctionTreeClique jtNode2 = sep.getChild(); assertThat(sep.getParent().getBitSet()).isEqualTo(clique1); assertThat(jtNode2.getBitSet()).isEqualTo(clique2); - assertThat(jtNode2.getChildren().size()).isEqualTo(2); + assertThat(jtNode2.getChildren()).hasSize(2); // clique3 sep = jtNode2.getChildren().get(0); @@ -1125,7 +1124,7 @@ public void testFullExample1() { JunctionTreeClique jtNode3 =sep.getChild(); assertThat(sep.getParent().getBitSet()).isEqualTo(clique2); assertThat(jtNode3.getBitSet()).isEqualTo(clique3); - assertThat(jtNode3.getChildren().size()).isEqualTo(1); + assertThat(jtNode3.getChildren()).hasSize(1); // clique4 sep = jtNode3.getChildren().get(0); @@ -1133,7 +1132,7 @@ public void testFullExample1() { JunctionTreeClique jtNode4 = sep.getChild(); assertThat(sep.getParent().getBitSet()).isEqualTo(clique3); assertThat(jtNode4.getBitSet()).isEqualTo(clique4); - assertThat(jtNode4.getChildren().size()).isEqualTo(0); + assertThat(jtNode4.getChildren()).isEmpty(); // clique5 sep = jtNode2.getChildren().get(1); @@ -1141,7 +1140,7 @@ public void testFullExample1() { JunctionTreeClique jtNode5 = sep.getChild(); assertThat(sep.getParent().getBitSet()).isEqualTo(clique2); assertThat(jtNode5.getBitSet()).isEqualTo(clique5); - assertThat(jtNode5.getChildren().size()).isEqualTo(1); + assertThat(jtNode5.getChildren()).hasSize(1); //clique 6 sep = jtNode5.getChildren().get(0); @@ -1149,7 +1148,7 @@ public void testFullExample1() { JunctionTreeClique jtNode6 = sep.getChild(); assertThat(sep.getParent().getBitSet()).isEqualTo(clique5); assertThat(jtNode6.getBitSet()).isEqualTo(clique6); - assertThat(jtNode6.getChildren().size()).isEqualTo(0); + assertThat(jtNode6.getChildren()).isEmpty(); } @Test @@ -1214,7 +1213,7 @@ public void testFullExample2() { // clique1 assertThat(root.getBitSet()).isEqualTo(clique1); - assertThat(root.getChildren().size()).isEqualTo(1); + assertThat(root.getChildren()).hasSize(1); // clique2 JunctionTreeSeparator sep = root.getChildren().get(0); @@ -1222,7 +1221,7 @@ public void testFullExample2() { JunctionTreeClique jtNode2 = sep.getChild(); assertThat(sep.getParent().getBitSet()).isEqualTo(clique1); assertThat(jtNode2.getBitSet()).isEqualTo(clique2); - assertThat(jtNode2.getChildren().size()).isEqualTo(2); + assertThat(jtNode2.getChildren()).hasSize(2); // clique3 assertThat(jtNode2.getParentSeparator()).isSameAs(sep); @@ -1231,7 +1230,7 @@ public void testFullExample2() { JunctionTreeClique jtNode3 = sep.getChild(); assertThat(sep.getParent().getBitSet()).isEqualTo(clique2); assertThat(jtNode3.getBitSet()).isEqualTo(clique3); - assertThat(jtNode3.getChildren().size()).isEqualTo(0); + assertThat(jtNode3.getChildren()).isEmpty(); // clique4 sep = jtNode2.getChildren().get(1); @@ -1239,7 +1238,7 @@ public void testFullExample2() { JunctionTreeClique jtNode4 = sep.getChild(); assertThat(sep.getParent().getBitSet()).isEqualTo(clique2); assertThat(jtNode4.getBitSet()).isEqualTo(clique4); - assertThat(jtNode4.getChildren().size()).isEqualTo(0); + assertThat(jtNode4.getChildren()).isEmpty(); } } diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/JunctionTreeTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/JunctionTreeTest.java index 9787252a3e1..cb8d228fc6a 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/JunctionTreeTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/JunctionTreeTest.java @@ -18,12 +18,10 @@ */ package org.drools.beliefs.bayes; -import junit.framework.AssertionFailedError; - import org.drools.beliefs.graph.Graph; import org.drools.beliefs.graph.GraphNode; import org.drools.util.bitmask.OpenBitSet; -import org.junit.Test; +import org.junit.jupiter.api.Test; import java.math.BigDecimal; import java.util.Arrays; @@ -109,11 +107,11 @@ public void testPotentialMultiplication1() { PotentialMultiplier m = new PotentialMultiplier(b.getProbabilityTable(), 1, parentVarPos, parentIndexMultipliers, vars, multipliers, potentials); m.multiple(); - assertArray(new double[]{0.1, 0.2, 0.3, 0.4}, potentials); + assertThat(potentials).containsExactly(0.1, 0.2, 0.3, 0.4); // test that it's applying variable multiplications correctly ontop of each other. This simulates the application of project variabe multiplications m.multiple(); - assertArray(new double[]{0.01, 0.04, 0.09, 0.16}, scaleDouble( 3, potentials )); + assertThat(scaleDouble(3, potentials)).containsExactly(0.01, 0.04, 0.09, 0.16); } @Test @@ -145,11 +143,11 @@ public void testPotentialMultiplication2() { PotentialMultiplier m = new PotentialMultiplier(c.getProbabilityTable(), 2, parentVarPos, parentIndexMultipliers, vars, multipliers, potentials); m.multiple(); - assertArray(new double[]{0.1, 0.1, 0.2, 0.2, 0.3, 0.3, 0.4, 0.4, 0.5, 0.5, 0.6, 0.6, 0.7, 0.7, 0.8, 0.8}, scaleDouble( 3, potentials )); + assertThat(scaleDouble( 3, potentials )).containsExactly(0.1, 0.1, 0.2, 0.2, 0.3, 0.3, 0.4, 0.4, 0.5, 0.5, 0.6, 0.6, 0.7, 0.7, 0.8, 0.8); // test that it's applying variable multiplications correctly ontop of each other. This simulates the application of project variabe multiplications m.multiple(); - assertArray(new double[]{0.01, 0.01, 0.04, 0.04, 0.09, 0.09, 0.16, 0.16, 0.25, 0.25, 0.36, 0.36, 0.49, 0.49, 0.64, 0.64}, scaleDouble( 3, potentials ) ); + assertThat(scaleDouble( 3, potentials )).containsExactly(0.01, 0.01, 0.04, 0.04, 0.09, 0.09, 0.16, 0.16, 0.25, 0.25, 0.36, 0.36, 0.49, 0.49, 0.64, 0.64); } @Test @@ -181,11 +179,11 @@ public void testPotentialMultiplication3() { PotentialMultiplier m = new PotentialMultiplier(c.getProbabilityTable(), 2, parentVarPos, parentIndexMultipliers, vars, multipliers, potentials); m.multiple(); - assertArray(new double[]{0.1, 0.3, 0.2, 0.4, 0.5, 0.7, 0.6, 0.8, 0.1, 0.3, 0.2, 0.4, 0.5, 0.7, 0.6, 0.8}, potentials); + assertThat(potentials).containsExactly(0.1, 0.3, 0.2, 0.4, 0.5, 0.7, 0.6, 0.8, 0.1, 0.3, 0.2, 0.4, 0.5, 0.7, 0.6, 0.8); // test that it's applying variable multiplications correctly ontop of each other. This simulates the application of project variabe multiplications m.multiple(); - assertArray(new double[]{0.01, 0.09, 0.04, 0.16, 0.25, 0.49, 0.36, 0.64, 0.01, 0.09, 0.04, 0.16, 0.25, 0.49, 0.36, 0.64}, scaleDouble( 3, potentials ) ); + assertThat(scaleDouble( 3, potentials )).containsExactly(0.01, 0.09, 0.04, 0.16, 0.25, 0.49, 0.36, 0.64, 0.01, 0.09, 0.04, 0.16, 0.25, 0.49, 0.36, 0.64); } @Test @@ -228,27 +226,11 @@ public void testJunctionTreeInitialisation() { JunctionTree jtree = new JunctionTree(graph, node1, new JunctionTreeClique[] { node1, node2 }, null ); - assertArray(new double[]{0.1, 0.2, 0.1, 0.2}, scaleDouble( 3, node1.getPotentials() )); - assertArray(new double[]{0.01, 0.02, 0.06, 0.08}, scaleDouble( 3, node2.getPotentials() )); + assertThat(scaleDouble(3, node1.getPotentials())).containsExactly(0.1, 0.2, 0.1, 0.2); + + assertThat(scaleDouble(3, node2.getPotentials())).containsExactly(0.01, 0.02, 0.06, 0.08); } - public static void assertArray(double[] expected, double[] actual) { - if ( !Arrays.equals(expected, actual) ) { - System.err.print( "expected " ); - for ( int i = 0; i ("Cloudy", cloudyNode.getId(), new String[]{"true", "false"}, new double[][]{{0.5, 0.5}}); BayesVariable sprinkler = new BayesVariable("Sprinkler", sprinklerNode.getId(), new String[]{"true", "false"}, new double[][]{{0.5, 0.5}, {0.9, 0.1}}); - BayesVariable rain = new BayesVariable( "Rain", rainNode.getId(), new String[] { "true", "false" }, new double[][] { { 0.8, 0.2 }, { 0.2, 0.8 } } ); - BayesVariable wetGrass = new BayesVariable( "WetGrass", wetGrassNode.getId(), new String[] { "true", "false" }, new double[][] { { 1.0, 0.0 }, { 0.1, 0.9 }, { 0.1, 0.9 }, { 0.01, 0.99 } } ); + BayesVariable rain = new BayesVariable("Rain", rainNode.getId(), new String[] { "true", "false" }, new double[][] { { 0.8, 0.2 }, { 0.2, 0.8 } }); + BayesVariable wetGrass = new BayesVariable("WetGrass", wetGrassNode.getId(), new String[] { "true", "false" }, new double[][] { { 1.0, 0.0 }, { 0.1, 0.9 }, { 0.1, 0.9 }, { 0.01, 0.99 } }); JunctionTree jTree; - @Before + @BeforeEach public void setUp() { - connectParentToChildren( cloudyNode, sprinklerNode, rainNode); - connectParentToChildren( sprinklerNode, wetGrassNode); - connectParentToChildren( rainNode, wetGrassNode); + connectParentToChildren(cloudyNode, sprinklerNode, rainNode); + connectParentToChildren(sprinklerNode, wetGrassNode); + connectParentToChildren(rainNode, wetGrassNode); cloudyNode.setContent(cloudy); - sprinklerNode.setContent( sprinkler); - rainNode.setContent( rain ); - wetGrassNode.setContent( wetGrass ); + sprinklerNode.setContent(sprinkler); + rainNode.setContent(rain); + wetGrassNode.setContent(wetGrass); - JunctionTreeBuilder jtBuilder = new JunctionTreeBuilder( graph ); + JunctionTreeBuilder jtBuilder = new JunctionTreeBuilder(graph); jTree = jtBuilder.build(); } @@ -71,79 +71,79 @@ public void testInitialize() { JunctionTreeClique jtNode = jTree.getRoot(); // cloud, rain sprinkler - assertArray(new double[]{0.2, 0.05, 0.2, 0.05, 0.09, 0.36, 0.01, 0.04 }, scaleDouble( 3, jtNode.getPotentials() )); + assertThat(scaleDouble(3, jtNode.getPotentials())).containsExactly(0.2, 0.05, 0.2, 0.05, 0.09, 0.36, 0.01, 0.04); // wetGrass jtNode = jTree.getRoot().getChildren().get(0).getChild(); - assertArray(new double[]{1.0, 0.0, 0.1, 0.9, 0.1, 0.9, 0.01, 0.99 }, scaleDouble( 3, jtNode.getPotentials() )); + assertThat(scaleDouble(3, jtNode.getPotentials())).containsExactly(1.0, 0.0, 0.1, 0.9, 0.1, 0.9, 0.01, 0.99); } @Test public void testNoEvidence() { - JunctionTreeBuilder jtBuilder = new JunctionTreeBuilder( graph ); + JunctionTreeBuilder jtBuilder = new JunctionTreeBuilder(graph); JunctionTree jTree = jtBuilder.build(); JunctionTreeClique jtNode = jTree.getRoot(); BayesInstance bayesInstance = new BayesInstance(jTree); bayesInstance.globalUpdate(); - assertArray(new double[]{0.5, 0.5}, scaleDouble(3, bayesInstance.marginalize("Cloudy").getDistribution())); + assertThat(scaleDouble(3, bayesInstance.marginalize("Cloudy").getDistribution())).containsExactly(0.5, 0.5); - assertArray( new double[]{0.5, 0.5}, scaleDouble( 3, bayesInstance.marginalize("Rain").getDistribution() ) ); + assertThat(scaleDouble(3, bayesInstance.marginalize("Rain").getDistribution())).containsExactly(0.5, 0.5); - assertArray( new double[]{0.7, 0.3}, scaleDouble(3, bayesInstance.marginalize("Sprinkler").getDistribution()) ); + assertThat(scaleDouble(3, bayesInstance.marginalize("Sprinkler").getDistribution())).containsExactly(0.7, 0.3); - assertArray( new double[]{0.353, 0.647}, scaleDouble( 3, bayesInstance.marginalize("WetGrass").getDistribution() ) ); + assertThat(scaleDouble(3, bayesInstance.marginalize("WetGrass").getDistribution())).containsExactly(0.353, 0.647); } @Test public void testGrassWetEvidence() { - JunctionTreeBuilder jtBuilder = new JunctionTreeBuilder( graph ); + JunctionTreeBuilder jtBuilder = new JunctionTreeBuilder(graph); JunctionTree jTree = jtBuilder.build(); JunctionTreeClique jtNode = jTree.getRoot(); BayesInstance bayesInstance = new BayesInstance(jTree); - bayesInstance.setLikelyhood( "WetGrass", new double[]{1.0, 0.0} ); + bayesInstance.setLikelyhood("WetGrass", new double[]{1.0, 0.0}); bayesInstance.globalUpdate(); - assertArray(new double[]{0.639, 0.361}, scaleDouble(3, bayesInstance.marginalize("Cloudy").getDistribution())); + assertThat(scaleDouble(3, bayesInstance.marginalize("Cloudy").getDistribution())).containsExactly(0.639, 0.361); - assertArray( new double[]{0.881, 0.119}, scaleDouble( 3, bayesInstance.marginalize("Rain").getDistribution() ) ); + assertThat(scaleDouble(3, bayesInstance.marginalize("Rain").getDistribution())).containsExactly(0.881, 0.119); - assertArray( new double[]{0.938, 0.062}, scaleDouble(3, bayesInstance.marginalize("Sprinkler").getDistribution()) ); + assertThat(scaleDouble(3, bayesInstance.marginalize("Sprinkler").getDistribution())).containsExactly(0.938, 0.062); - assertArray( new double[]{1.0, 0.0}, scaleDouble( 3, bayesInstance.marginalize("WetGrass").getDistribution() ) ); + assertThat(scaleDouble(3, bayesInstance.marginalize("WetGrass").getDistribution())).containsExactly(1.0, 0.0); } @Test public void testSprinklerEvidence() { - JunctionTreeBuilder jtBuilder = new JunctionTreeBuilder( graph ); + JunctionTreeBuilder jtBuilder = new JunctionTreeBuilder(graph); JunctionTree jTree = jtBuilder.build(); JunctionTreeClique jtNode = jTree.getRoot(); BayesInstance bayesInstance = new BayesInstance(jTree); - bayesInstance.setLikelyhood( "Sprinkler", new double[]{1.0, 0.0} ); - bayesInstance.setLikelyhood( "Cloudy", new double[]{1.0, 0.0} ); + bayesInstance.setLikelyhood("Sprinkler", new double[]{1.0, 0.0}); + bayesInstance.setLikelyhood("Cloudy", new double[]{1.0, 0.0}); bayesInstance.globalUpdate(); - assertArray(new double[]{1.0, 0.0}, scaleDouble(3, bayesInstance.marginalize("Cloudy").getDistribution())); + assertThat(scaleDouble(3, bayesInstance.marginalize("Cloudy").getDistribution())).containsExactly(1.0, 0.0); - assertArray( new double[]{0.8, 0.2}, scaleDouble( 3, bayesInstance.marginalize("Rain").getDistribution() ) ); + assertThat(scaleDouble(3, bayesInstance.marginalize("Rain").getDistribution())).containsExactly(0.8, 0.2); - assertArray( new double[]{1.0, 0.0}, scaleDouble(3, bayesInstance.marginalize("Sprinkler").getDistribution()) ); + assertThat(scaleDouble(3, bayesInstance.marginalize("Sprinkler").getDistribution())).containsExactly(1.0, 0.0); - assertArray( new double[]{0.82, 0.18}, scaleDouble( 3, bayesInstance.marginalize("WetGrass").getDistribution() ) ); + assertThat(scaleDouble(3, bayesInstance.marginalize("WetGrass").getDistribution())).containsExactly(0.82, 0.18); } public static void marginalize(BayesVariableState varState, CliqueState cliqueState) { JunctionTreeClique jtNode = cliqueState.getJunctionTreeClique(); - new Marginalizer(jtNode.getValues().toArray( new BayesVariable[jtNode.getValues().size()]), cliqueState.getPotentials(), varState.getVariable(), varState.getDistribution() ); - System.out.print( varState.getVariable().getName() + " " ); - for ( double d : varState.getDistribution() ) { + new Marginalizer(jtNode.getValues().toArray(new BayesVariable[jtNode.getValues().size()]), cliqueState.getPotentials(), varState.getVariable(), varState.getDistribution()); + System.out.print(varState.getVariable().getName() + " "); + for (double d : varState.getDistribution()) { System.out.print(d); System.out.print(" "); } @@ -152,12 +152,12 @@ public static void marginalize(BayesVariableState varState, CliqueState cliqueS public static GraphNode addNode(Graph graph) { GraphNode x = graph.addNode(); - x.setContent( new BayesVariable( "x" + x.getId(), x.getId(), new String[] { "a", "b" }, new double[][] { { 0.1, 0.1 } } ) ); + x.setContent(new BayesVariable("x" + x.getId(), x.getId(), new String[] { "a", "b" }, new double[][] { { 0.1, 0.1 } })); return x; } public static void connectParentToChildren(GraphNode parent, GraphNode... children) { - for ( GraphNode child : children ) { + for (GraphNode child : children) { EdgeImpl e = new EdgeImpl(); e.setOutGraphNode(parent); e.setInGraphNode(child); diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/AssemblerTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/AssemblerTest.java index 639433d3e8c..bee6c7eb0ce 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/AssemblerTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/AssemblerTest.java @@ -20,8 +20,8 @@ import org.drools.beliefs.bayes.assembler.BayesPackage; import org.drools.compiler.builder.impl.KnowledgeBuilderImpl; +import org.junit.jupiter.api.Test; import org.drools.base.definitions.InternalKnowledgePackage; -import org.junit.Test; import org.kie.api.io.ResourceType; import org.kie.internal.io.ResourceFactory; diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/BayesBeliefSystemTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/BayesBeliefSystemTest.java index 1736cef5411..2789052745c 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/BayesBeliefSystemTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/BayesBeliefSystemTest.java @@ -33,7 +33,7 @@ import org.drools.kiesession.rulebase.InternalKnowledgeBase; import org.drools.kiesession.rulebase.KnowledgeBaseFactory; import org.drools.kiesession.session.StatefulKnowledgeSessionImpl; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.kie.api.io.ResourceType; import org.kie.api.runtime.KieSession; import org.kie.api.runtime.KieSessionConfiguration; diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/BayesRuntimeTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/BayesRuntimeTest.java index 18ade7b8550..72fdc12ecaa 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/BayesRuntimeTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/BayesRuntimeTest.java @@ -24,7 +24,7 @@ import org.drools.kiesession.rulebase.InternalKnowledgeBase; import org.drools.kiesession.rulebase.SessionsAwareKnowledgeBase; import org.drools.kiesession.session.StatefulKnowledgeSessionImpl; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.kie.api.io.ResourceType; import org.kie.internal.io.ResourceFactory; diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/ParserTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/ParserTest.java index e8207f4dd7f..03084d43a23 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/ParserTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/ParserTest.java @@ -26,9 +26,8 @@ import org.drools.beliefs.bayes.model.Variable; import org.drools.beliefs.bayes.model.XmlBifParser; import org.drools.beliefs.graph.GraphNode; -import org.junit.Test; +import org.junit.jupiter.api.Test; -import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; @@ -46,39 +45,34 @@ public void testSprinklerLoadBif() { assertThat(network.getProperties().get(0)).isEqualTo("package = org.drools.beliefs.bayes.integration"); Map varMap = varToMap( network.getVariables() ); - assertThat(varMap.size()).isEqualTo(4); + assertThat(varMap).hasSize(4); Variable var = varMap.get("WetGrass"); assertThat(var.getName()).isEqualTo("WetGrass"); - assertThat(var.getOutComes().size()).isEqualTo(2); - assertThat(Arrays.asList("false", "true")).isEqualTo(var.getOutComes()); + assertThat(var.getOutComes()).hasSize(2).containsExactly("false", "true"); assertThat(var.getProperties().get(0)).isEqualTo("position = (0,10)"); var = varMap.get("Cloudy"); assertThat(var.getName()).isEqualTo("Cloudy"); - assertThat(var.getOutComes().size()).isEqualTo(2); - assertThat(Arrays.asList("false", "true")).isEqualTo(var.getOutComes()); + assertThat(var.getOutComes()).hasSize(2).containsExactly("false", "true"); assertThat(var.getProperties().get(0)).isEqualTo("position = (0,-10)"); var = varMap.get("Sprinkler"); assertThat(var.getName()).isEqualTo("Sprinkler"); - assertThat(var.getOutComes().size()).isEqualTo(2); - assertThat(Arrays.asList("false", "true")).isEqualTo(var.getOutComes()); + assertThat(var.getOutComes()).hasSize(2).containsExactly("false", "true"); assertThat(var.getProperties().get(0)).isEqualTo("position = (13,0)"); var = varMap.get("Rain"); assertThat(var.getName()).isEqualTo("Rain"); - assertThat(var.getOutComes().size()).isEqualTo(2); - assertThat(Arrays.asList("false", "true")).isEqualTo(var.getOutComes()); + assertThat(var.getOutComes()).hasSize(2).containsExactly("false", "true"); assertThat(var.getProperties().get(0)).isEqualTo("position = (-12,0)"); Map defMap = defToMap( network.getDefinitions() ); - assertThat(defMap.size()).isEqualTo(4); + assertThat(defMap).hasSize(4); Definition def = defMap.get( "WetGrass"); assertThat(def.getName()).isEqualTo("WetGrass"); - assertThat(def.getGiven().size()).isEqualTo(2); - assertThat(Arrays.asList("Sprinkler", "Rain")).isEqualTo(def.getGiven()); + assertThat(def.getGiven()).hasSize(2).containsExactly("Sprinkler", "Rain"); assertThat(def.getProbabilities()).isEqualTo("1.0 0.0 0.1 0.9 0.1 0.9 0.01 0.99"); def = defMap.get( "Cloudy"); @@ -88,8 +82,7 @@ public void testSprinklerLoadBif() { def = defMap.get( "Sprinkler"); assertThat(def.getName()).isEqualTo("Sprinkler"); - assertThat(def.getGiven().size()).isEqualTo(1); - assertThat(def.getGiven().get(0)).isEqualTo("Cloudy"); + assertThat(def.getGiven()).hasSize(1).containsExactly("Cloudy"); assertThat(def.getProbabilities().trim()).isEqualTo("0.5 0.5 0.9 0.1"); def = defMap.get( "Rain"); @@ -107,29 +100,28 @@ public void testSprinklerBuildBayesNework() { GraphNode node = map.get( "WetGrass" ); BayesVariable wetGrass = node.getContent(); - assertThat(Arrays.asList(wetGrass.getOutcomes())).isEqualTo(Arrays.asList("false", "true")); - assertThat(wetGrass.getGiven().length).isEqualTo(2); - assertThat(Arrays.asList("Sprinkler", "Rain")).isEqualTo(Arrays.asList(wetGrass.getGiven())); - assertThat(Arrays.deepEquals(new double[][]{{1.0, 0.0}, {0.1, 0.9}, {0.1, 0.9}, {0.01, 0.99}}, wetGrass.getProbabilityTable())).isTrue(); + assertThat(wetGrass.getOutcomes()).containsExactly("false", "true"); + assertThat(wetGrass.getGiven()).hasSize(2).containsExactly("Sprinkler", "Rain"); + assertThat(wetGrass.getProbabilityTable()).isDeepEqualTo(new double[][]{{1.0, 0.0}, {0.1, 0.9}, {0.1, 0.9}, {0.01, 0.99}}); node = map.get( "Sprinkler" ); BayesVariable sprinkler = node.getContent(); - assertThat(Arrays.asList(sprinkler.getOutcomes())).isEqualTo(Arrays.asList("false", "true")); - assertThat(sprinkler.getGiven().length).isEqualTo(1); + assertThat(wetGrass.getOutcomes()).containsExactly("false", "true"); + assertThat(sprinkler.getGiven()).hasSize(1); assertThat(sprinkler.getGiven()[0]).isEqualTo("Cloudy"); - assertThat(Arrays.deepEquals(new double[][]{{0.5, 0.5}, {0.9, 0.1}}, sprinkler.getProbabilityTable())).isTrue(); + assertThat(sprinkler.getProbabilityTable()).isDeepEqualTo(new double[][]{{0.5, 0.5}, {0.9, 0.1}}); node = map.get( "Cloudy" ); BayesVariable cloudy = node.getContent(); - assertThat(Arrays.asList(cloudy.getOutcomes())).isEqualTo(Arrays.asList("false", "true")); - assertThat(cloudy.getGiven().length).isEqualTo(0); - assertThat(Arrays.deepEquals(new double[][]{{0.5, 0.5}}, cloudy.getProbabilityTable())).isTrue(); + assertThat(wetGrass.getOutcomes()).containsExactly("false", "true"); + assertThat(cloudy.getGiven()).isEmpty(); + assertThat(cloudy.getProbabilityTable()).isDeepEqualTo(new double[][]{{0.5, 0.5}}); node = map.get( "Rain" ); BayesVariable rain = node.getContent(); - assertThat(Arrays.asList(rain.getOutcomes())).isEqualTo(Arrays.asList("false", "true")); - assertThat(rain.getGiven().length).isEqualTo(0); - assertThat(Arrays.deepEquals(new double[][]{{0.5, 0.5}}, rain.getProbabilityTable())).isTrue(); + assertThat(rain.getOutcomes()).containsExactly("false", "true"); + assertThat(rain.getGiven()).isEmpty(); + assertThat(rain.getProbabilityTable()).isDeepEqualTo(new double[][]{{0.5, 0.5}}); } Map> nodeToMap(BayesNetwork network) { diff --git a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/WeaverTest.java b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/WeaverTest.java index 60daf82220b..a7951f34bc7 100644 --- a/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/WeaverTest.java +++ b/drools-beliefs/src/test/java/org/drools/beliefs/bayes/integration/WeaverTest.java @@ -25,7 +25,7 @@ import org.drools.base.definitions.ResourceTypePackageRegistry; import org.drools.kiesession.rulebase.InternalKnowledgeBase; import org.drools.kiesession.rulebase.KnowledgeBaseFactory; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.kie.api.io.ResourceType; import org.kie.internal.io.ResourceFactory; diff --git a/drools-commands/pom.xml b/drools-commands/pom.xml index 1568464ee93..2064c6d6937 100644 --- a/drools-commands/pom.xml +++ b/drools-commands/pom.xml @@ -55,11 +55,11 @@ jakarta.xml.bind-api provided - - junit - junit - test - + + org.junit.jupiter + junit-jupiter + test + org.assertj assertj-core diff --git a/drools-commands/src/test/java/org/drools/commands/DeleteCommandTest.java b/drools-commands/src/test/java/org/drools/commands/DeleteCommandTest.java index 18b43f716ab..9d760880658 100644 --- a/drools-commands/src/test/java/org/drools/commands/DeleteCommandTest.java +++ b/drools-commands/src/test/java/org/drools/commands/DeleteCommandTest.java @@ -22,9 +22,9 @@ import org.drools.commands.runtime.rule.InsertObjectCommand; import org.drools.kiesession.rulebase.InternalKnowledgeBase; import org.drools.kiesession.rulebase.KnowledgeBaseFactory; -import org.junit.After; -import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; import org.kie.api.runtime.Context; import org.kie.api.runtime.ExecutableRunner; import org.kie.api.runtime.KieSession; @@ -40,7 +40,7 @@ public class DeleteCommandTest { private ExecutableRunner runner; private Context context; - @Before + @BeforeEach public void setup() { InternalKnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase(); ksession = kbase.newKieSession(); @@ -48,7 +48,7 @@ public void setup() { context = ((RegistryContext) runner.createContext()).register(KieSession.class, ksession); } - @After + @AfterEach public void cleanUp() { ksession.dispose(); } diff --git a/drools-commands/src/test/java/org/drools/commands/ExecuteCommandDisconnectedTest.java b/drools-commands/src/test/java/org/drools/commands/ExecuteCommandDisconnectedTest.java index 7e7c6084e5c..62bad906c15 100644 --- a/drools-commands/src/test/java/org/drools/commands/ExecuteCommandDisconnectedTest.java +++ b/drools-commands/src/test/java/org/drools/commands/ExecuteCommandDisconnectedTest.java @@ -25,7 +25,7 @@ import org.drools.core.common.DefaultFactHandle; import org.drools.commands.runtime.ExecutionResultImpl; import org.drools.kiesession.rulebase.KnowledgeBaseFactory; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.kie.api.KieBase; import org.kie.api.command.BatchExecutionCommand; import org.kie.api.runtime.ExecutableRunner; diff --git a/drools-commands/src/test/java/org/drools/commands/FromExternalFactHandleCommandTest.java b/drools-commands/src/test/java/org/drools/commands/FromExternalFactHandleCommandTest.java index 0960ea2c6b2..989629e9f7e 100644 --- a/drools-commands/src/test/java/org/drools/commands/FromExternalFactHandleCommandTest.java +++ b/drools-commands/src/test/java/org/drools/commands/FromExternalFactHandleCommandTest.java @@ -21,9 +21,8 @@ import org.drools.commands.runtime.rule.FromExternalFactHandleCommand; import org.drools.kiesession.rulebase.InternalKnowledgeBase; import org.drools.kiesession.rulebase.KnowledgeBaseFactory; -import org.junit.After; -import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; import org.kie.api.runtime.Context; import org.kie.api.runtime.ExecutableRunner; import org.kie.api.runtime.KieSession; @@ -39,7 +38,7 @@ public class FromExternalFactHandleCommandTest { private ExecutableRunner runner; private Context context; - @Before + @BeforeEach public void setup() { InternalKnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase(); ksession = kbase.newKieSession(); @@ -47,12 +46,12 @@ public void setup() { context = ((RegistryContext) runner.createContext()).register(KieSession.class, ksession); } - @After + @AfterEach public void cleanUp() { ksession.dispose(); } - @Test + @org.junit.jupiter.api.Test public void testFromExternalFactHandleCommandNumberFormatException() { // DROOLS-7076 : Just to test not to throw NumberFormatException String externalFormat = "0:2147483648:171497379:-1361525545:2147483648:null:NON_TRAIT:java.lang.String"; diff --git a/drools-commands/src/test/java/org/drools/commands/GetFactHandlesCommandTest.java b/drools-commands/src/test/java/org/drools/commands/GetFactHandlesCommandTest.java index 47b921efbf3..c4e70e3e9dd 100644 --- a/drools-commands/src/test/java/org/drools/commands/GetFactHandlesCommandTest.java +++ b/drools-commands/src/test/java/org/drools/commands/GetFactHandlesCommandTest.java @@ -27,9 +27,9 @@ import org.drools.core.common.InternalFactHandle; import org.drools.kiesession.rulebase.InternalKnowledgeBase; import org.drools.kiesession.rulebase.KnowledgeBaseFactory; -import org.junit.After; -import org.junit.Before; -import org.junit.Test; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; import org.kie.api.runtime.Context; import org.kie.api.runtime.ExecutableRunner; import org.kie.api.runtime.KieSession; @@ -47,7 +47,7 @@ public class GetFactHandlesCommandTest { private Context context; private Random random = new Random(); - @Before + @BeforeEach public void setup() { InternalKnowledgeBase kbase = KnowledgeBaseFactory.newKnowledgeBase(); ksession = kbase.newKieSession(); @@ -55,7 +55,7 @@ public void setup() { context = ( (RegistryContext) runner.createContext() ).register( KieSession.class, ksession ); } - @After + @AfterEach public void cleanUp() { ksession.dispose(); } diff --git a/drools-commands/src/test/java/org/drools/commands/InternalExecutableTest.java b/drools-commands/src/test/java/org/drools/commands/InternalExecutableTest.java index 22a0ad616c9..9600d118da2 100644 --- a/drools-commands/src/test/java/org/drools/commands/InternalExecutableTest.java +++ b/drools-commands/src/test/java/org/drools/commands/InternalExecutableTest.java @@ -25,7 +25,7 @@ import org.drools.commands.fluent.BatchImpl; import org.drools.commands.fluent.InternalExecutable; import org.drools.commands.impl.NotTransactionalCommand; -import org.junit.Test; +import org.junit.jupiter.api.Test; import org.kie.api.command.ExecutableCommand; import org.kie.api.runtime.Context; diff --git a/drools-compiler/src/main/java/org/drools/compiler/kie/builder/impl/ClasspathKieProject.java b/drools-compiler/src/main/java/org/drools/compiler/kie/builder/impl/ClasspathKieProject.java index 7d9a7aa9b6f..c9ad2df0db4 100644 --- a/drools-compiler/src/main/java/org/drools/compiler/kie/builder/impl/ClasspathKieProject.java +++ b/drools-compiler/src/main/java/org/drools/compiler/kie/builder/impl/ClasspathKieProject.java @@ -45,6 +45,7 @@ import org.drools.compiler.kie.builder.impl.event.KieServicesEventListerner; import org.drools.compiler.kproject.models.KieModuleModelImpl; import org.drools.util.IoUtils; +import org.drools.util.JarUtils; import org.drools.util.PortablePath; import org.drools.util.StringUtils; import org.kie.api.KieServices; @@ -410,6 +411,9 @@ public static String fixURLFromKProjectPath(URL url) { urlPath = urlPath.substring( 0, urlPath.length() - 1 ); } + // Replace "/!BOOT-INF/" with "!/BOOT-INF/" to make it consistent with the actual path in the jar file + urlPath = JarUtils.replaceNestedPathForSpringBoot32(urlPath); + // remove any remaining protocols, normally only if it was a jar int firstSlash = urlPath.indexOf( '/' ); colonIndex = firstSlash > 0 ? urlPath.lastIndexOf( ":", firstSlash ) : urlPath.lastIndexOf( ":" ); diff --git a/drools-docs/src/modules/ROOT/pages/language-reference/_DSL-section.adoc b/drools-docs/src/modules/ROOT/pages/language-reference/_DSL-section.adoc deleted file mode 100644 index 6adfcd0c2de..00000000000 --- a/drools-docs/src/modules/ROOT/pages/language-reference/_DSL-section.adoc +++ /dev/null @@ -1,417 +0,0 @@ -//// -Licensed to the Apache Software Foundation (ASF) under one -or more contributor license agreements. See the NOTICE file -distributed with this work for additional information -regarding copyright ownership. The ASF licenses this file -to you 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. -//// - -= Domain Specific Languages - - -(((Domain Specific Languages))) -Domain Specific Languages (or DSLs) are a way of creating a rule language that is dedicated to your problem domain. -A set of DSL definitions consists of transformations from DSL "sentences" to DRL constructs, which lets you use of all the underlying rule language and engine features. -Given a DSL, you write rules in DSL rule (or DSLR) files, which will be translated into DRL files. - -DSL and DSLR files are plain text files, and you can use any text editor to create and modify them. -But there are also DSL and DSLR editors, both in the IDE as well as in the web based BRMS, and you can use those as well, although they may not provide you with the full DSL functionality. - -== When to Use a DSL - - -DSLs can serve as a layer of separation between rule authoring (and rule authors) and the technical intricacies resulting from the modelling of domain object and the {RULE_ENGINE}'s native language and methods. -If your rules need to be read and validated by domain experts (such as business analysts, for instance) who are not programmers, you should consider using a DSL; it hides implementation details and focuses on the rule logic proper. -DSL sentences can also act as "templates" for conditional elements and consequence actions that are used repeatedly in your rules, possibly with minor variations. -You may define DSL sentences as being mapped to these repeated phrases, with parameters providing a means for accommodating those variations. - -DSLs have no impact on the {RULE_ENGINE} at runtime, they are just a compile time feature, requiring a special parser and transformer. - -== DSL Basics - - -The Drools DSL mechanism allows you to customise conditional expressions and consequence actions. -A global substitution mechanism ("keyword") is also available. - -.Example (((DSL))) DSL mapping -==== -[source] ----- -[when]Something is {colour}=Something(colour=="{colour}") ----- -==== - - -In the preceding example, `[when]` indicates the scope of the expression, i.e., whether it is valid for the LHS or the RHS of a rule. -The part after the bracketed keyword is the expression that you use in the rule; typically a natural language expression, but it doesn't have to be. -The part to the right of the equal sign ("=") is the mapping of the expression into the rule language. -The form of this string depends on its destination, RHS or LHS. -If it is for the LHS, then it ought to be a term according to the regular LHS syntax; if it is for the RHS then it might be a Java statement. - -Whenever the DSL parser matches a line from the rule file written in the DSL with an expression in the DSL definition, it performs three steps of string manipulation. -First, it extracts the string values appearing where the expression contains variable names in braces (here: ``\{colour}``). Then, the values obtained from these captures are then interpolated wherever that name, again enclosed in braces, occurs on the right hand side of the mapping. -Finally, the interpolated string replaces whatever was matched by the entire expression in the line of the DSL rule file. - -Note that the expressions (i.e., the strings on the left hand side of the equal sign) are used as regular expressions in a pattern matching operation against a line of the DSL rule file, matching all or part of a line. -This means you can use (for instance) a '?' to indicate that the preceding character is optional. -One good reason to use this is to overcome variations in natural language phrases of your DSL. -But, given that these expressions are regular expression patterns, this also means that all "magic" characters of Java's pattern syntax have to be escaped with a preceding backslash ('\'). - -It is important to note that the compiler transforms DSL rule files line by line. -In the previous example, all the text after "Something is " to the end of the line is captured as the replacement value for "\{colour}", and this is used for interpolating the target string. -This may not be exactly what you want. -For instance, when you intend to merge different DSL expressions to generate a composite DRL pattern, you need to transform a DSLR line in several independent operations. -The best way to achieve this is to ensure that the captures are surrounded by characteristic text - words or even single characters. -As a result, the matching operation done by the parser plucks out a substring from somewhere within the line. -In the example below, quotes are used as distinctive characters. -Note that the characters that surround the capture are not included during interpolation, just the contents between them. - -As a rule of thumb, use quotes for textual data that a rule editor may want to enter. -You can also enclose the capture with words to ensure that the text is correctly matched. -Both is illustrated by the following example. -Note that a single line such as `Something is "green" and - another solid thing` is now correctly expanded. - -.Example with quotes -==== -[source] ----- -[when]something is "{colour}"=Something(colour=="{colour}") -[when]another {state} thing=OtherThing(state=="{state})" ----- -==== - - -It is a good idea to avoid punctuation (other than quotes or apostrophes) in your DSL expressions as much as possible. -The main reason is that punctuation is easy to forget for rule authors using your DSL. -Another reason is that parentheses, the period and the question mark are magic characters, requiring escaping in the DSL definition. - -In a DSL mapping, the braces "{" and "}" should only be used to enclose a variable definition or reference, resulting in a capture. -If they should occur literally, either in the expression or within the replacement text on the right hand side, they must be escaped with a preceding backslash ("\"): - -[source] ----- -[then]do something= if (foo) \{ doSomething(); \} ----- - -[NOTE] -==== -If braces "{" and "}" should appear in the replacement string of a DSL definition, escape them with a backslash ('\'). -==== - -.Examples of DSL mapping entries -==== -[source] ----- -# This is a comment to be ignored. -[when]There is a person with name of "{name}"=Person(name=="{name}") -[when]Person is at least {age} years old and lives in "{location}"= - Person(age >= {age}, location=="{location}") -[then]Log "{message}"=System.out.println("{message}"); -[when]And = and ----- -==== - - -Given the above DSL examples, the following examples show the expansion of various DSLR snippets: - -.Examples of DSL expansions -==== -[source] ----- -There is a person with name of "Kitty" - ==> Person(name="Kitty") -Person is at least 42 years old and lives in "Atlanta" - ==> Person(age >= 42, location="Atlanta") -Log "boo" - ==> System.out.println("boo"); -There is a person with name of "Bob" And Person is at least 30 years old and lives in "Utah" - ==> Person(name="Bob") and Person(age >= 30, location="Utah") ----- -==== - -[NOTE] -==== -Don't forget that if you are capturing plain text from a DSL rule line and want to use it as a string literal in the expansion, you must provide the quotes on the right hand side of the mapping. -==== - - -You can chain DSL expressions together on one line, as long as it is clear to the parser where one ends and the next one begins and where the text representing a parameter ends. -(Otherwise you risk getting all the text until the end of the line as a parameter value.) The DSL expressions are tried, one after the other, according to their order in the DSL definition file. -After any match, all remaining DSL expressions are investigated, too. - -The resulting DRL text may consist of more than one line. -Line ends are in the replacement text are written as ``\n``. - -== Adding Constraints to Facts - - -A common requirement when writing rule conditions is to be able to add an arbitrary combination of constraints to a pattern. -Given that a fact type may have many fields, having to provide an individual DSL statement for each combination would be plain folly. - -The DSL facility allows you to add constraints to a pattern by a simple convention: if your DSL expression starts with a hyphen (minus character, "-") it is assumed to be a field constraint and, consequently, is is added to the last pattern line preceding it. - -For an example, lets take look at class ``Cheese``, with the following fields: type, price, age and country. -We can express some LHS condition in normal DRL like the following - -[source] ----- -Cheese(age < 5, price == 20, type=="stilton", country=="ch") ----- - - -The DSL definitions given below result in three DSL phrases which may be used to create any combination of constraint involving these fields. - -[source] ----- -[when]There is a Cheese with=Cheese() -[when]- age is less than {age}=age<{age} -[when]- type is '{type}'=type=='{type}' -[when]- country equal to '{country}'=country=='{country}' ----- - - -You can then write rules with conditions like the following: -[source] ----- -There is a Cheese with - - age is less than 42 - - type is 'stilton' ----- - The parser will pick up a line beginning with "-" and add it as a constraint to the preceding pattern, inserting a comma when it is required. -For the preceding example, the resulting DRL is: -[source] ----- -Cheese(age<42, type=='stilton') ----- - -Combining all numeric fields with all relational operators (according to the DSL expression "age is less than..." in the preceding example) produces an unwieldy amount of DSL entries. -But you can define DSL phrases for the various operators and even a generic expression that handles any field constraint, as shown below. -(Notice that the expression definition contains a regular expression in addition to the variable name.) - -[source] ----- -[when][]is less than or equal to=<= -[when][]is less than=< -[when][]is greater than or equal to=>= -[when][]is greater than=> -[when][]is equal to=== -[when][]equals=== -[when][]There is a Cheese with=Cheese() -[when][]- {field:\w*} {operator} {value:\d*}={field} {operator} {value} ----- - - -Given these DSL definitions, you can write rules with conditions such as: - -[source] ----- -There is a Cheese with - - age is less than 42 - - rating is greater than 50 - - type equals 'stilton' ----- - - -In this specific case, a phrase such as "is less than" is replaced by ``<``, and then the line matches the last DSL entry. -This removes the hyphen, but the final result is still added as a constraint to the preceding pattern. -After processing all of the lines, the resulting DRL text is: - -[source] ----- -Cheese(age<42, rating > 50, type=='stilton') ----- - -[NOTE] -==== -The order of the entries in the DSL is important if separate DSL expressions are intended to match the same line, one after the other. -==== - -== Developing a DSL - - -A good way to get started is to write representative samples of the rules your application requires, and to test them as you develop. -This will provide you with a stable framework of conditional elements and their constraints. -Rules, both in DRL and in DSLR, refer to entities according to the data model representing the application data that should be subject to the reasoning process defined in rules. -Notice that writing rules is generally easier if most of the data model's types are facts. - -Given an initial set of rules, it should be possible to identify recurring or similar code snippets and to mark variable parts as parameters. -This provides reliable leads as to what might be a handy DSL entry. -Also, make sure you have a full grasp of the jargon the domain experts are using, and base your DSL phrases on this vocabulary. - -You may postpone implementation decisions concerning conditions and actions during this first design phase by leaving certain conditional elements and actions in their DRL form by prefixing a line with a greater sign (">"). (This is also handy for inserting debugging statements.) - -During the next development phase, you should find that the DSL configuration stabilizes pretty quickly. -New rules can be written by reusing the existing DSL definitions, or by adding a parameter to an existing condition or consequence entry. - -Try to keep the number of DSL entries small. -Using parameters lets you apply the same DSL sentence for similar rule patterns or constraints. -But do not exaggerate: authors using the DSL should still be able to identify DSL phrases by some fixed text. - -== DSL and DSLR Reference - - -A DSL file is a text file in a line-oriented format. -Its entries are used for transforming a DSLR file into a file according to DRL syntax. - -* A line starting with "\#" or "//" (with or without preceding white space) is treated as a comment. A comment line starting with "#/" is scanned for words requesting a debug option, see below. -* Any line starting with an opening bracket ("[") is assumed to be the first line of a DSL entry definition. -* Any other line is appended to the preceding DSL entry definition, with the line end replaced by a space. - - -A DSL entry consists of the following four parts: - -* A scope definition, written as one of the keywords "when" or "condition", "then" or "consequence", "*" and "keyword", enclosed in brackets ("[" and "]"). This indicates whether the DSL entry is valid for the condition or the consequence of a rule, or both. A scope indication of "keyword" means that the entry has global significance, i.e., it is recognized anywhere in a DSLR file. -* A type definition, written as a Java class name, enclosed in brackets. This part is optional unless the next part begins with an opening bracket. An empty pair of brackets is valid, too. -* A DSL expression consists of a (Java) regular expression, with any number of embedded _variable definitions,_ terminated by an equal sign ("="). A variable definition is enclosed in braces ("{" and "}"). It consists of a variable name and two optional attachments, separated by colons (":"). If there is one attachment, it is a regular expression for matching text that is to be assigned to the variable; if there are two attachments, the first one is a hint for the GUI editor and the second one the regular expression. -+ -Note that all characters that are "magic" in regular expressions must be escaped with a preceding backslash ("\") if they should occur literally within the expression. -* The remaining part of the line after the delimiting equal sign is the replacement text for any DSLR text matching the regular expression. It may contain variable references, i.e., a variable name enclosed in braces. Optionally, the variable name may be followed by an exclamation mark ("!") and a transformation function, see below. -+ -Note that braces ("{" and "}") must be escaped with a preceding backslash ("\") if they should occur literally within the replacement string. - - -Debugging of DSL expansion can be turned on, selectively, by using a comment line starting with "#/" which may contain one or more words from the table presented below. -The resulting output is written to standard output. - -.Debug options for DSL expansion -[cols="1,1", options="header"] -|=== -| Word -| Description - -|result -|Prints the resulting DRL text, with line numbers. - -|steps -|Prints each expansion step of condition and consequence - lines. - -|keyword -|Dumps the internal representation of all DSL entries with - scope "keyword". - -|when -|Dumps the internal representation of all DSL entries with - scope "when" or "*". - -|then -|Dumps the internal representation of all DSL entries with - scope "then" or "*". - -|usage -|Displays a usage statistic of all DSL entries. -|=== - - -Below are some sample DSL definitions, with comments describing the language features they illustrate. - -[source] ----- -# Comment: DSL examples - -#/ debug: display result and usage - -# keyword definition: replaces "regula" by "rule" -[keyword][]regula=rule - -# conditional element: "T" or "t", "a" or "an", convert matched word -[when][][Tt]here is an? {entity:\w+}= - ${entity!lc}: {entity!ucfirst} () - -# consequence statement: convert matched word, literal braces -[then][]update {entity:\w+}=modify( ${entity!lc} )\{ \} ----- - - -The transformation of a DSLR file proceeds as follows: - -. The text is read into memory. -. Each of the "keyword" entries is applied to the entire text. First, the regular expression from the keyword definition is modified by replacing white space sequences with a pattern matching any number of white space characters, and by replacing variable definitions with a capture made from the regular expression provided with the definition, or with the default (".*?"). Then, the DSLR text is searched exhaustively for occurrences of strings matching the modified regular expression. Substrings of a matching string corresponding to variable captures are extracted and replace variable references in the corresponding replacement text, and this text replaces the matching string in the DSLR text. -. Sections of the DSLR text between "when" and "then", and "then" and "end", respectively, are located and processed in a uniform manner, line by line, as described below. -+ -For a line, each DSL entry pertaining to the line's section is taken in turn, in the order it appears in the DSL file. -Its regular expression part is modified: white space is replaced by a pattern matching any number of white space characters; variable definitions with a regular expression are replaced by a capture with this regular expression, its default being ".*?". If the resulting regular expression matches all or part of the line, the matched part is replaced by the suitably modified replacement text. -+ -Modification of the replacement text is done by replacing variable references with the text corresponding to the regular expression capture. -This text may be modified according to the string transformation function given in the variable reference; see below for details. -+ -If there is a variable reference naming a variable that is not defined in the same entry, the expander substitutes a value bound to a variable of that name, provided it was defined in one of the preceding lines of the current rule. -. If a DSLR line in a condition is written with a leading hyphen, the expanded result is inserted into the last line, which should contain a pattern CE, i.e., a type name followed by a pair of parentheses. if this pair is empty, the expanded line (which should contain a valid constraint) is simply inserted, otherwise a comma (",") is inserted beforehand. -+ -If a DSLR line in a consequence is written with a leading hyphen, the expanded result is inserted into the last line, which should contain a "modify" statement, ending in a pair of braces ("{" and "}"). If this pair is empty, the expanded line (which should contain a valid method call) is simply inserted, otherwise a comma (",") is inserted beforehand. - - -[NOTE] -==== -It is currently _not_ possible to use a line with a leading hyphen to insert text into other conditional element forms (e.g., "accumulate") or it may only work for the first insertion (e.g., "eval"). -==== - - -All string transformation functions are described in the following table. - -.String transformation functions -[cols="1,1", options="header"] -|=== -| Name -| Description - -|uc -|Converts all letters to upper case. - -|lc -|Converts all letters to lower case. - -|ucfirst -|Converts the first letter to upper case, and - all other letters to lower case. - -|num -|Extracts all digits and "-" from the string. If the - last two digits in the original string are preceded by "." or - ",", a decimal period is inserted in the corresponding position. - -|__a__?__b__/__c__ -|Compares the string with string __a__, and if they - are equal, replaces it with __b__, otherwise with - __c__. But _c_ can be another triplet - __a__, __b__, __c__, so - that the entire structure is, in fact, a translation table. -|=== - - -The following DSL examples show how to use string transformation functions. - -[source] ----- -# definitions for conditions -[when][]There is an? {entity}=${entity!lc}: {entity!ucfirst}() -[when][]- with an? {attr} greater than {amount}={attr} <= {amount!num} -[when][]- with a {what} {attr}={attr} {what!positive?>0/negative?%lt;0/zero?==0/ERROR} ----- - - -A file containing a DSL definition has to be put under the resources folder or any of its subfolders like any other drools artifact. -It must have the extension ``$$.$$dsl``, or alternatively be marked with type ``ResourceType.DSL``. -when programmatically added to a ``KieFileSystem``. -For a file using DSL definition, the extension `$$.$$dslr` should be used, while it can be added to a `KieFileSystem` with type ``ResourceType.DSLR``. - -For parsing and expanding a DSLR file the DSL configuration is read and supplied to the parser. -Thus, the parser can "recognize" the DSL expressions and transform them into native rule language expressions. - -ifdef::backend-docbook[] -[index] -== Index -// Generated automatically by the DocBook toolchain. -endif::backend-docbook[] diff --git a/drools-docs/src/modules/ROOT/pages/language-reference/index.adoc b/drools-docs/src/modules/ROOT/pages/language-reference/index.adoc index b468a9ebacd..95de660cfd0 100644 --- a/drools-docs/src/modules/ROOT/pages/language-reference/index.adoc +++ b/drools-docs/src/modules/ROOT/pages/language-reference/index.adoc @@ -28,6 +28,4 @@ include::_drl-rules.adoc[leveloffset=+1] include::_performance-tuning-drl-ref.adoc[leveloffset=+2] -include::_DSL-section.adoc[leveloffset=+1] - include::_XLSDecisionTable-section.adoc[leveloffset=+1] diff --git a/drools-impact-analysis/drools-impact-analysis-parser/src/main/java/org/drools/impact/analysis/parser/impl/RhsParser.java b/drools-impact-analysis/drools-impact-analysis-parser/src/main/java/org/drools/impact/analysis/parser/impl/RhsParser.java index d11ef174a0c..735b36881e4 100644 --- a/drools-impact-analysis/drools-impact-analysis-parser/src/main/java/org/drools/impact/analysis/parser/impl/RhsParser.java +++ b/drools-impact-analysis/drools-impact-analysis-parser/src/main/java/org/drools/impact/analysis/parser/impl/RhsParser.java @@ -97,7 +97,7 @@ private Class getActionClass(RuleContext context, MethodCallExpr consequenceE Expression actionArg = statement.getArgument(0); Class actionClass = null; if (actionArg.isNameExpr()) { - actionClass = context.getTypedDeclarationById(actionArg.toString()).map(TypedDeclarationSpec::getDeclarationClass) + actionClass = context.getTypedDeclarationById(actionArg.toString()).>map(TypedDeclarationSpec::getDeclarationClass) .orElseGet(() -> getClassFromAssignment(consequenceExpr, actionArg)); } else if (actionArg.isLiteralExpr()) { actionClass = literalType(actionArg.asLiteralExpr()); diff --git a/drools-model/drools-model-codegen/src/main/java/org/drools/model/codegen/execmodel/generator/visitor/accumulate/AccumulateVisitor.java b/drools-model/drools-model-codegen/src/main/java/org/drools/model/codegen/execmodel/generator/visitor/accumulate/AccumulateVisitor.java index e998f3a3578..f0a06a9d2eb 100644 --- a/drools-model/drools-model-codegen/src/main/java/org/drools/model/codegen/execmodel/generator/visitor/accumulate/AccumulateVisitor.java +++ b/drools-model/drools-model-codegen/src/main/java/org/drools/model/codegen/execmodel/generator/visitor/accumulate/AccumulateVisitor.java @@ -281,7 +281,8 @@ private Optional methodCallExprParameter(PatternDescr basePattern, B String rootNodeName = getRootNodeName(methodCallWithoutRootNode); Optional decl = context.getTypedDeclarationById(rootNodeName); - Class clazz = decl.map(TypedDeclarationSpec::getDeclarationClass) + + Class clazz = decl.>map(TypedDeclarationSpec::getDeclarationClass) .orElseGet( () -> { try { return context.getTypeResolver().resolveType(rootNodeName); diff --git a/drools-mvel/src/test/java/org/drools/mvel/BuildUtilsTest.java b/drools-mvel/src/test/java/org/drools/mvel/BuildUtilsTest.java index 4e0f558957b..692c6450246 100644 --- a/drools-mvel/src/test/java/org/drools/mvel/BuildUtilsTest.java +++ b/drools-mvel/src/test/java/org/drools/mvel/BuildUtilsTest.java @@ -116,33 +116,12 @@ public void testCalculateTemporalDistance() { and.addChild( not ); TemporalDependencyMatrix matrix = utils.calculateTemporalDistance( and ); - //printMatrix( matrix.getMatrix() ); - assertEqualsMatrix( expected, matrix.getMatrix() ); - + + assertThat(matrix.getMatrix()).isDeepEqualTo(expected); assertThat(matrix.getExpirationOffset(a)).isEqualTo(15); assertThat(matrix.getExpirationOffset(d)).isEqualTo(11); assertThat(matrix.getExpirationOffset(e)).isEqualTo(1); } - - public void assertEqualsMatrix( Interval[][] expected, Interval[][] matrix ) { - for( int i = 0; i < matrix.length; i++ ) { - for( int j = 0; j < matrix[i].length; j++ ) { - assertThat(matrix[i][j]).as("Wrong value at (" + i + ", " + j).isEqualTo(expected[i][j]); - } - } - } - - public void printMatrix( Interval[][] matrix ) { - System.out.println("------------------------------------------------------------------"); - for( int i = 0; i < matrix.length; i++ ) { - System.out.print("| "); - for( int j = 0; j < matrix[i].length; j++ ) { - System.out.print( matrix[i][j] + " "); - } - System.out.println("|"); - } - System.out.println("------------------------------------------------------------------"); - } } diff --git a/drools-test-coverage/test-compiler-integration/src/test/java/org/drools/compiler/integrationtests/operators/NotTest.java b/drools-test-coverage/test-compiler-integration/src/test/java/org/drools/compiler/integrationtests/operators/NotTest.java index 6416b6e48c8..9cdd7ed1a35 100644 --- a/drools-test-coverage/test-compiler-integration/src/test/java/org/drools/compiler/integrationtests/operators/NotTest.java +++ b/drools-test-coverage/test-compiler-integration/src/test/java/org/drools/compiler/integrationtests/operators/NotTest.java @@ -311,4 +311,26 @@ public void testNotWithInnerJoin() { assertThat(results.size()).isEqualTo(1); assertThat(results.get(0)).isEqualTo("Paris"); } + + @Test + public void testNotWithUnification() { + // DROOLS-7629 + final String drl = + "package org.drools.compiler.integrationtests.operators;\n" + + "rule R1 when\n" + + " ( not ( $rao_v2 := String() and (\n" + + " $rao_v2 := String()\n" + + " ) ) and (\n" + + " $rao_v2 := String()\n" + + " )\n" + + " )\n" + + "then\n" + + "end"; + + final KieBase kbase = KieBaseUtil.getKieBaseFromKieModuleFromDrl("not-test", kieBaseTestConfiguration, drl); + final KieSession ksession = kbase.newKieSession(); + + ksession.insert("test"); + assertThat(ksession.fireAllRules()).isEqualTo(0); + } } diff --git a/drools-util/src/main/java/org/drools/util/JarUtils.java b/drools-util/src/main/java/org/drools/util/JarUtils.java index c944826d661..eb7789f632b 100644 --- a/drools-util/src/main/java/org/drools/util/JarUtils.java +++ b/drools-util/src/main/java/org/drools/util/JarUtils.java @@ -26,6 +26,9 @@ public class JarUtils { private static final String SPRING_BOOT_PREFIX = "BOOT-INF/classes/"; // Actual path prefix in Spring Boot JAR private static final String SPRING_BOOT_URL_PREFIX = "BOOT-INF/classes!/"; // Spring Boot adds "!" to resource url as a "nest" separator + private static final String SPRING_BOOT_NESTED_PREFIX_BEFORE_3_2 = "!/BOOT-INF/"; // Before Spring Boot 3.2 + private static final String SPRING_BOOT_NESTED_PREFIX_AFTER_3_2 = "/!BOOT-INF/"; // Since Spring Boot 3.2 + private JarUtils() { // Avoid instantiating class } @@ -45,4 +48,17 @@ public static String normalizeSpringBootResourceUrlPath(String resourceUrlPath) return resourceUrlPath; } } + + /** + * Replace the new spring-boot nested path representation "/!BOOT-INF/" (introduced since 3.2) with the old "!/BOOT-INF/". + * Because the new path representation doesn't meet the path manipulation in the drools codebase. + * See https://github.com/spring-projects/spring-boot/wiki/Spring-Boot-3.2-Release-Notes#nested-jar-support + */ + public static String replaceNestedPathForSpringBoot32(String urlPath) { + if (urlPath.contains(SPRING_BOOT_NESTED_PREFIX_AFTER_3_2)) { + return urlPath.replace(SPRING_BOOT_NESTED_PREFIX_AFTER_3_2, SPRING_BOOT_NESTED_PREFIX_BEFORE_3_2); + } else { + return urlPath; + } + } } diff --git a/drools-util/src/test/java/org/drools/util/JarUtilsTest.java b/drools-util/src/test/java/org/drools/util/JarUtilsTest.java index a2c6794fd28..6453cc595c0 100644 --- a/drools-util/src/test/java/org/drools/util/JarUtilsTest.java +++ b/drools-util/src/test/java/org/drools/util/JarUtilsTest.java @@ -29,4 +29,16 @@ public void normalizeSpringBootResourceUrlPath() { String normalized = JarUtils.normalizeSpringBootResourceUrlPath("BOOT-INF/classes!/org/example/MyClass.class"); assertThat(normalized).isEqualTo("BOOT-INF/classes/org/example/MyClass.class"); } + + @Test + public void replaceNestedPathForSpringBoot32_shouldNotAffectOldPath() { + String result = JarUtils.replaceNestedPathForSpringBoot32("/dir/myapp.jar!/BOOT-INF/lib/mykjar.jar"); + assertThat(result).isEqualTo("/dir/myapp.jar!/BOOT-INF/lib/mykjar.jar"); + } + + @Test + public void replaceNestedPathForSpringBoot32_shouldReplaceNewPath() { + String result = JarUtils.replaceNestedPathForSpringBoot32("/dir/myapp.jar/!BOOT-INF/lib/mykjar.jar"); + assertThat(result).isEqualTo("/dir/myapp.jar!/BOOT-INF/lib/mykjar.jar"); + } } \ No newline at end of file