import java.util.StringTokenizer; import junit.framework.TestCase; import java.io.*; public class Assign4Test extends TestCase { public Assign4Test (String name) { super(name); } /** * The following 9 check methods create an interpreter object with the * specified String as the program, invoke the respective evaluation * method (valueValue, valueName, valueNeed, etc.), and check that the * result matches the (given) expected output. */ private void valueValueCheck(String name, String answer, String program) { Interpreter interp = new Interpreter(new StringReader(program)); assertEquals("by-value-value " + name, answer, interp.valueValue().toString()); } private void valueNameCheck(String name, String answer, String program) { Interpreter interp = new Interpreter(new StringReader(program)); assertEquals("by-value-name " + name, answer, interp.valueName().toString()); } private void valueNeedCheck(String name, String answer, String program) { Interpreter interp = new Interpreter(new StringReader(program)); assertEquals("by-value-need " + name, answer, interp.valueNeed().toString()); } private void nameValueCheck(String name, String answer, String program) { Interpreter interp = new Interpreter(new StringReader(program)); assertEquals("by-value " + name, answer, interp.nameValue().toString()); } private void nameNameCheck(String name, String answer, String program) { Interpreter interp = new Interpreter(new StringReader(program)); assertEquals("by-name " + name, answer, interp.nameName().toString()); } private void nameNeedCheck(String name, String answer, String program) { Interpreter interp = new Interpreter(new StringReader(program)); assertEquals("by-need " + name, answer, interp.nameNeed().toString()); } private void needValueCheck(String name, String answer, String program) { Interpreter interp = new Interpreter(new StringReader(program)); assertEquals("by-value " + name, answer, interp.needValue().toString()); } private void needNameCheck(String name, String answer, String program) { Interpreter interp = new Interpreter(new StringReader(program)); assertEquals("by-name " + name, answer, interp.needName().toString()); } private void needNeedCheck(String name, String answer, String program) { Interpreter interp = new Interpreter(new StringReader(program)); assertEquals("by-need " + name, answer, interp.needNeed().toString()); } private void allCheck(String name, String answer, String program) { valueValueCheck(name, answer, program); valueNameCheck(name, answer, program); valueNeedCheck(name, answer, program); nameValueCheck(name, answer, program); nameNameCheck(name, answer, program); nameNeedCheck(name, answer, program); needValueCheck(name, answer, program); needNameCheck(name, answer, program); needNeedCheck(name, answer, program); } private void noNameCheck(String name, String answer, String program) { valueValueCheck(name, answer, program); valueNameCheck(name, answer, program); valueNeedCheck(name, answer, program); needValueCheck(name, answer, program); needNameCheck(name, answer, program); needNeedCheck(name, answer, program); } private void needCheck(String name, String answer, String program) { needValueCheck(name, answer, program); needNeedCheck(name, answer, program); } private void lazyCheck(String name, String answer, String program) { valueNameCheck(name, answer, program); valueNeedCheck(name, answer, program); nameNameCheck(name, answer, program); nameNeedCheck(name, answer, program); needNameCheck(name, answer, program); needNeedCheck(name, answer, program); } public void testNumberP() { try { String output = "number?"; String input = "number?"; allCheck("numberP", output, input ); } catch (Exception e) { e.printStackTrace(); fail("numberP threw " + e); } } //end of func public void testMathOp() { try { String output = "18"; String input = "2 * 3 + 12"; allCheck("mathOp", output, input ); } catch (Exception e) { e.printStackTrace(); fail("mathOp threw " + e); } } //end of func public void testParseException() { try { String output = "haha"; String input = " 1 +"; allCheck("parseException", output, input ); fail("parseException did not throw ParseException exception"); } catch (ParseException e) { //e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); fail("parseException threw " + e); } } //end of func public void testEvalException() { try { String output = "mojo"; String input = "1 + number?"; allCheck("evalException", output, input ); fail("evalException did not throw EvalException exception"); } catch (EvalException e) { //e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); fail("evalException threw " + e); } } //end of func public void testAppend() { try { String output = "(1 2 3 1 2 3)"; String input = "let Y := map f to let g := map x to f(map z1,z2 to (x(x))(z1,z2)); in g(g); APPEND := map ap to map x,y to if x = empty then y else cons(first(x), ap(rest(x), y)); l := cons(1,cons(2,cons(3,empty))); in (Y(APPEND))(l,l)"; allCheck("append", output, input ); } catch (Exception e) { e.printStackTrace(); fail("append threw " + e); } } //end of func public void testLetRec() { try { String output = "(1 2 3 1 2 3)"; String input = "let append := map x,y to if x = empty then y else cons(first(x), append(rest(x), y)); l := cons(1,cons(2,cons(3,empty))); in append(l,l)"; allCheck("letRec", output, input ); } catch (Exception e) { e.printStackTrace(); fail("letRec threw " + e); } } //end of func public void testLazyCons() { try { String output = "0"; String input = "let zeroes := cons(0,zeroes);in first(rest(zeroes))"; lazyCheck("lazyCons", output, input ); } catch (Exception e) { e.printStackTrace(); fail("lazyCons threw " + e); } } //end of func public void testEmptyBlock() { try { String output = "0"; String input = "{ }"; allCheck("emptyBlock", output, input ); fail("emptyBlock did not throw ParseException exception"); } catch (ParseException e) { //e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); fail("emptyBlock threw " + e); } } //end of func public void testBlock() { try { String output = "1"; String input = "{3; 2; 1}"; allCheck("block", output, input ); } catch (Exception e) { e.printStackTrace(); fail("block threw " + e); } } //end of func public void testDupVar() { try { String output = "ha!"; String input = "let x:=3; x:=4; in x"; allCheck("dupVar", output, input ); fail("dupVar did not throw SyntaxException exception"); } catch (SyntaxException e) { //e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); fail("dupVar threw " + e); } } //end of func public void testRefApp() { try { String output = "(ref 17)"; String input = "let x := ref 10; in {x <- 17; x}"; noNameCheck("refApp", output, input ); nameNameCheck("refApp [name]", "(ref 10)", input); } catch (Exception e) { e.printStackTrace(); fail("refApp threw " + e); } } //end of func public void testRefref() { try { String output = "(ref (ref 4))"; String input = "let x:= ref 4; y:= ref x; in y"; allCheck("refref", output, input ); } catch (Exception e) { e.printStackTrace(); fail("refref threw " + e); } } //end of func public void testBangApp() { try { String output = "10"; String input = "let x := ref 10; in !x"; allCheck("bangApp", output, input ); } catch (Exception e) { e.printStackTrace(); fail("bangApp threw " + e); } } //end of func }