1 package test.net.sourceforge.pmd.rules.design; 2 3 import net.sourceforge.pmd.PMD; 4 import net.sourceforge.pmd.Rule; 5 import net.sourceforge.pmd.RuleSetNotFoundException; 6 import test.net.sourceforge.pmd.testframework.SimpleAggregatorTst; 7 import test.net.sourceforge.pmd.testframework.TestDescriptor; 8 9 public class EmptyStatementNotInLoopRuleTest extends SimpleAggregatorTst { 10 11 private Rule rule; 12 13 public void setUp() throws RuleSetNotFoundException { 14 rule = findRule("rulesets/basic.xml", "EmptyStatementNotInLoop"); 15 } 16 17 public void testAll() { 18 runTests(new TestDescriptor[] { 19 new TestDescriptor(TEST1, "ok, semicolon after for", 0, rule), 20 new TestDescriptor(TEST2, "ok, semicolon after while", 0, rule), 21 new TestDescriptor(TEST3, "bad, random semicolon", 1, rule), 22 new TestDescriptor(TEST4, "bad, double semicolon", 1, rule), 23 }); 24 } 25 26 private static final String TEST1 = 27 "public class Foo {" + PMD.EOL + 28 " void bar() {" + PMD.EOL + 29 " for (int i=2; i<10; i++);" + PMD.EOL + 30 " }" + PMD.EOL + 31 "}"; 32 33 private static final String TEST2 = 34 "public class Foo {" + PMD.EOL + 35 " void bar() {" + PMD.EOL + 36 " while (i++ < 20);" + PMD.EOL + 37 " }" + PMD.EOL + 38 "}"; 39 40 private static final String TEST3 = 41 "public class Foo {" + PMD.EOL + 42 " void bar() {" + PMD.EOL + 43 " ;" + PMD.EOL + 44 " }" + PMD.EOL + 45 "}"; 46 47 private static final String TEST4 = 48 "public class Foo {" + PMD.EOL + 49 " void bar() {" + PMD.EOL + 50 " int x = 2;;" + PMD.EOL + 51 " }" + PMD.EOL + 52 "}"; 53 }