X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2Fmisc%2FRegressionTests.java;h=dfe30b63f4f8f85d5893b48d7477fe452f3a06e9;hp=d57959056b5baa39f181eb8286dbbcfc26e5ef56;hb=bbb16d2522ed587238fd7a69e346d5e5e8f2551a;hpb=f8adfc66d98670be6553965d7ee9e6c998a4e0a6 diff --git a/src/edu/berkeley/sbp/misc/RegressionTests.java b/src/edu/berkeley/sbp/misc/RegressionTests.java index d579590..dfe30b6 100644 --- a/src/edu/berkeley/sbp/misc/RegressionTests.java +++ b/src/edu/berkeley/sbp/misc/RegressionTests.java @@ -1,13 +1,11 @@ -// Copyright 2006 all rights reserved; see LICENSE file for BSD-style license +// Copyright 2006-2007 all rights reserved; see LICENSE file for BSD-style license package edu.berkeley.sbp.misc; 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,9 +13,18 @@ public class RegressionTests { public static boolean yes = false; public static boolean graph = false; + public static GrammarAST.ImportResolver resolver = new GrammarAST.ImportResolver() { + public InputStream getImportStream(String importname) { + try { + return new FileInputStream("tests/"+importname); + } catch (IOException e) { + throw new RuntimeException(e); + } + } + }; public static void main() throws Exception { - main(new String[] { "tests/meta.g", "tests/testcase.g", "tests/regression.tc" }); + main(new String[] { null, "tests/testcase.g", "tests/regression.tc" }); } public static void main(String[] s) throws Exception { @@ -36,14 +43,31 @@ public class RegressionTests { s = s2; } - System.err.println("parsing " + s[0]); - Tree res = new CharParser(MetaGrammar.newInstance()).parse(new FileInputStream(s[0])).expand1(); - Union meta = Grammar.create(res, "s"); + CharParser cp; + Tree res; + + InputStream metaGrammarStream = + s[0] == null + ? RegressionTests.class.getClassLoader().getResourceAsStream("edu/berkeley/sbp/meta/meta.g") + : new FileInputStream(s[0]); + res = new CharParser(GrammarAST.getMetaGrammar()).parse(metaGrammarStream).expand1(); + Union meta = GrammarAST.buildFromAST(res, "s", resolver); + cp = new CharParser(meta); + + System.err.println("serializing grammar to grammar.ser..."); + ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("grammar.ser")); + oos.writeObject(cp); + oos.close(); + + System.err.println("deserializing grammar from grammar.ser..."); + ObjectInputStream ois = new ObjectInputStream(new FileInputStream("grammar.ser")); + cp = (CharParser)ois.readObject(); + ois.close(); System.err.println("parsing " + s[1]); res = new CharParser(meta).parse(new FileInputStream(s[1])).expand1(); - Union testcasegrammar = Grammar.create(res, "s"); + Union testcasegrammar = GrammarAST.buildFromAST(res, "s", resolver); if (testcasegrammar==null) return; CharParser parser = new CharParser(testcasegrammar); @@ -64,7 +88,25 @@ public class RegressionTests { } System.err.println("expanding..."); - TestCase[] expanded = (TestCase[])new GrammarBuilder("tests/", "").walkChildren(r2.expand1()); + ArrayList cases = new ArrayList(); + Tree tt = r2.expand1(); + for(int i=0; i> results = new HashSet>(); - if (res != null) res.expand(results); + if (output==null) { + System.out.println("\r\033[32mDONE\033[0m "+name); + return true; + } + 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);