diff --git a/pmd-java/src/test/java/net/sourceforge/pmd/lang/java/oom/DataStructureTest.java b/pmd-java/src/test/java/net/sourceforge/pmd/lang/java/oom/DataStructureTest.java index 8d3e2ae8a2..fa01499305 100644 --- a/pmd-java/src/test/java/net/sourceforge/pmd/lang/java/oom/DataStructureTest.java +++ b/pmd-java/src/test/java/net/sourceforge/pmd/lang/java/oom/DataStructureTest.java @@ -130,99 +130,54 @@ public class DataStructureTest extends ParserTst { @Test public void memoizationTest() { - - final List res = new ArrayList<>(); - final PackageStats toplevel = Metrics.getTopLevelPackageStats(); - ASTCompilationUnit acu = parseAndVisitForClass15(MetricsVisitorTestData.class); + List expected = visitWith(acu, true); + List real = visitWith(acu, false); + + assertEquals(expected, real); + } + + + private List visitWith(ASTCompilationUnit acu, final boolean force) { + final PackageStats toplevel = Metrics.getTopLevelPackageStats(); + + final List result = new ArrayList<>(); + acu.jjtAccept(new JavaParserVisitorReducedAdapter() { @Override public Object visit(ASTMethodOrConstructorDeclaration node, Object data) { - res.add((int) toplevel.compute(opMetricKey, node, true, Version.STANDARD)); + result.add((int) toplevel.compute(opMetricKey, node, force, Version.STANDARD)); return super.visit(node, data); } @Override public Object visit(ASTAnyTypeDeclaration node, Object data) { - res.add((int) toplevel.compute(classMetricKey, node, true, Version.STANDARD)); + result.add((int) toplevel.compute(classMetricKey, node, force, Version.STANDARD)); return super.visit(node, data); } }, null); - System.out.println(); - - final List cmp = new ArrayList<>(); - - acu.jjtAccept(new JavaParserVisitorReducedAdapter() { - @Override - public Object visit(ASTMethodOrConstructorDeclaration node, Object data) { - cmp.add((int) toplevel.compute(opMetricKey, node, false, Version.STANDARD)); - return super.visit(node, data); - } - - - @Override - public Object visit(ASTAnyTypeDeclaration node, Object data) { - cmp.add((int) toplevel.compute(classMetricKey, node, false, Version.STANDARD)); - return super.visit(node, data); - } - }, null); - - assertEquals(res, cmp); - + return result; } @Test public void forceMemoizationTest() { - - final List res = new ArrayList<>(); - final PackageStats toplevel = Metrics.getTopLevelPackageStats(); - ASTCompilationUnit acu = parseAndVisitForClass15(MetricsVisitorTestData.class); - acu.jjtAccept(new JavaParserVisitorReducedAdapter() { - @Override - public Object visit(ASTMethodOrConstructorDeclaration node, Object data) { - res.add((int) toplevel.compute(opMetricKey, node, true, Version.STANDARD)); - return super.visit(node, data); - } + List reference = visitWith(acu, true); + List real = visitWith(acu, true); + assertEquals(reference.size(), real.size()); - @Override - public Object visit(ASTAnyTypeDeclaration node, Object data) { - res.add((int) toplevel.compute(classMetricKey, node, true, Version.STANDARD)); - return super.visit(node, data); - } - }, null); - - System.out.println(); - - final List cmp = new ArrayList<>(); - - acu.jjtAccept(new JavaParserVisitorReducedAdapter() { - @Override - public Object visit(ASTMethodOrConstructorDeclaration node, Object data) { - cmp.add((int) toplevel.compute(opMetricKey, node, true, Version.STANDARD)); - return super.visit(node, data); - } - - - @Override - public Object visit(ASTAnyTypeDeclaration node, Object data) { - cmp.add((int) toplevel.compute(classMetricKey, node, true, Version.STANDARD)); - return super.visit(node, data); - } - }, null); - - for (int i = 0; i < res.size(); i++) { - assertNotEquals(res.get(i), cmp.get(i)); + // we force recomputation so each result should be different + for (int i = 0; i < reference.size(); i++) { + assertNotEquals(reference.get(i), real.get(i)); } - } - + /** * Test metric.