X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2Fmisc%2FRegressionTests.java;h=6fd3dd0df09546babf75aa4d52090bb03cd1c5d6;hp=d57959056b5baa39f181eb8286dbbcfc26e5ef56;hb=dc9bb3a45ed306e2e35549076842b3e74efecb48;hpb=449c39e0dafd7c736bfcd8d56bbd08b7a99e25a4 diff --git a/src/edu/berkeley/sbp/misc/RegressionTests.java b/src/edu/berkeley/sbp/misc/RegressionTests.java index d579590..6fd3dd0 100644 --- a/src/edu/berkeley/sbp/misc/RegressionTests.java +++ b/src/edu/berkeley/sbp/misc/RegressionTests.java @@ -5,9 +5,7 @@ import java.io.*; import java.util.*; import java.lang.reflect.*; import edu.berkeley.sbp.*; -import edu.berkeley.sbp.misc.*; import edu.berkeley.sbp.meta.*; -import edu.berkeley.sbp.tib.*; import edu.berkeley.sbp.chr.*; import edu.berkeley.sbp.util.*; @@ -15,6 +13,7 @@ public class RegressionTests { public static boolean yes = false; public static boolean graph = false; + public static File[] includes = new File[] { new File("tests") }; public static void main() throws Exception { main(new String[] { "tests/meta.g", "tests/testcase.g", "tests/regression.tc" }); @@ -38,12 +37,12 @@ public class RegressionTests { System.err.println("parsing " + s[0]); Tree res = new CharParser(MetaGrammar.newInstance()).parse(new FileInputStream(s[0])).expand1(); - Union meta = Grammar.create(res, "s"); + Union meta = GrammarBuilder.buildFromAST(res, "s", includes); System.err.println("parsing " + s[1]); res = new CharParser(meta).parse(new FileInputStream(s[1])).expand1(); - Union testcasegrammar = Grammar.create(res, "s"); + Union testcasegrammar = GrammarBuilder.buildFromAST(res, "s", includes); if (testcasegrammar==null) return; CharParser parser = new CharParser(testcasegrammar); @@ -64,7 +63,7 @@ public class RegressionTests { } System.err.println("expanding..."); - TestCase[] expanded = (TestCase[])new GrammarBuilder("tests/", "").walkChildren(r2.expand1()); + TestCase[] expanded = (TestCase[])new GrammarBuilder(includes, "").walkChildren(r2.expand1()); for(TestCase tc : expanded) tc.execute(); @@ -126,11 +125,11 @@ public class RegressionTests { System.out.println(parser); } - HashSet> results = new HashSet>(); - if (res != null) res.expand(results); + Iterable> results = + res==null ? new HashSet>() : res.expand(); System.out.print("\r"); - if (results == null || (results.size() == 0 && (output!=null && output.length > 0))) { + if (results == null || (!results.iterator().hasNext() && (output!=null && output.length > 0))) { System.out.print("\033[31m"); System.out.print("FAIL "); System.out.println("\033[0m "+name);