summaryrefslogtreecommitdiff
path: root/tiger-compiler/tests/unit
diff options
context:
space:
mode:
Diffstat (limited to 'tiger-compiler/tests/unit')
-rw-r--r--tiger-compiler/tests/unit/ast/local.am1
-rw-r--r--tiger-compiler/tests/unit/ast/test_hello.cc6
-rw-r--r--tiger-compiler/tests/unit/local.am4
-rw-r--r--tiger-compiler/tests/unit/misc/local.am5
-rw-r--r--tiger-compiler/tests/unit/misc/symbol/local.am2
-rw-r--r--tiger-compiler/tests/unit/misc/symbol/test_symbol_simple.cc21
-rw-r--r--tiger-compiler/tests/unit/misc/test_hello.cc6
-rw-r--r--tiger-compiler/tests/unit/misc/unique/local.am4
-rw-r--r--tiger-compiler/tests/unit/misc/unique/test_unique_char.cc18
-rw-r--r--tiger-compiler/tests/unit/misc/unique/test_unique_int.cc18
-rw-r--r--tiger-compiler/tests/unit/misc/unique/test_unique_string.cc19
-rw-r--r--tiger-compiler/tests/unit/misc/variant/local.am3
-rw-r--r--tiger-compiler/tests/unit/misc/variant/test_variant_three_types.cc35
-rw-r--r--tiger-compiler/tests/unit/misc/variant/test_variant_two_types.cc28
-rw-r--r--tiger-compiler/tests/unit/parse/local.am4
-rw-r--r--tiger-compiler/tests/unit/parse/test_hello.cc36
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_driver/local.am2
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_driver/test_parse_no_check.cc19
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/define_test_location.cc5
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/define_test_location.hh5
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/local.am12
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_array_exp.cc30
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_break_exp.cc30
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_call_exp.cc41
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_field_var.cc30
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_if_exp.cc48
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_int_exp.cc38
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_let_exp.cc30
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_object_exp.cc19
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_record_exp.cc30
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_record_ty.cc30
-rw-r--r--tiger-compiler/tests/unit/parse/tiger_factory/test_make_string_exp.cc30
-rw-r--r--tiger-compiler/tests/unit/tasks/bind/local.am0
-rw-r--r--tiger-compiler/tests/unit/tasks/local.am1
34 files changed, 610 insertions, 0 deletions
diff --git a/tiger-compiler/tests/unit/ast/local.am b/tiger-compiler/tests/unit/ast/local.am
new file mode 100644
index 0000000..6f01dc2
--- /dev/null
+++ b/tiger-compiler/tests/unit/ast/local.am
@@ -0,0 +1 @@
+check_unit_SOURCES += %D%/test_hello.cc
diff --git a/tiger-compiler/tests/unit/ast/test_hello.cc b/tiger-compiler/tests/unit/ast/test_hello.cc
new file mode 100644
index 0000000..b52d5ac
--- /dev/null
+++ b/tiger-compiler/tests/unit/ast/test_hello.cc
@@ -0,0 +1,6 @@
+#include <criterion/criterion.h>
+
+Test(ast, hello)
+{
+ 1;
+}
diff --git a/tiger-compiler/tests/unit/local.am b/tiger-compiler/tests/unit/local.am
new file mode 100644
index 0000000..f5e4165
--- /dev/null
+++ b/tiger-compiler/tests/unit/local.am
@@ -0,0 +1,4 @@
+include %D%/ast/local.am
+include %D%/misc/local.am
+include %D%/parse/local.am
+include %D%/tasks/local.am
diff --git a/tiger-compiler/tests/unit/misc/local.am b/tiger-compiler/tests/unit/misc/local.am
new file mode 100644
index 0000000..db96069
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/local.am
@@ -0,0 +1,5 @@
+include %D%/unique/local.am
+include %D%/symbol/local.am
+include %D%/variant/local.am
+
+check_unit_SOURCES += %D%/test_hello.cc
diff --git a/tiger-compiler/tests/unit/misc/symbol/local.am b/tiger-compiler/tests/unit/misc/symbol/local.am
new file mode 100644
index 0000000..fbc4825
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/symbol/local.am
@@ -0,0 +1,2 @@
+check_unit_SOURCES += \
+ %D%/test_symbol_simple.cc
diff --git a/tiger-compiler/tests/unit/misc/symbol/test_symbol_simple.cc b/tiger-compiler/tests/unit/misc/symbol/test_symbol_simple.cc
new file mode 100644
index 0000000..a49ed27
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/symbol/test_symbol_simple.cc
@@ -0,0 +1,21 @@
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <misc/symbol.hh>
+
+Test(test_symbol, simple)
+{
+ const misc::symbol toto1("toto");
+ const misc::symbol toto2("toto");
+ const misc::symbol titi1("titi");
+
+ cr_expect_eq(toto1, "toto");
+ cr_expect_neq(toto1, "titi");
+
+ cr_expect_eq(toto1, toto2);
+ cr_expect_neq(toto1, titi1);
+
+ std::string junk = "tata";
+ const misc::symbol tata1(junk);
+ junk = "toto";
+ cr_expect_eq(tata1, "tata");
+}
diff --git a/tiger-compiler/tests/unit/misc/test_hello.cc b/tiger-compiler/tests/unit/misc/test_hello.cc
new file mode 100644
index 0000000..e18e1d8
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/test_hello.cc
@@ -0,0 +1,6 @@
+#include <criterion/criterion.h>
+
+Test(misc, hello)
+{
+ 1;
+}
diff --git a/tiger-compiler/tests/unit/misc/unique/local.am b/tiger-compiler/tests/unit/misc/unique/local.am
new file mode 100644
index 0000000..9911c25
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/unique/local.am
@@ -0,0 +1,4 @@
+check_unit_SOURCES += \
+ %D%/test_unique_int.cc \
+ %D%/test_unique_char.cc \
+ %D%/test_unique_string.cc
diff --git a/tiger-compiler/tests/unit/misc/unique/test_unique_char.cc b/tiger-compiler/tests/unit/misc/unique/test_unique_char.cc
new file mode 100644
index 0000000..d69b42c
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/unique/test_unique_char.cc
@@ -0,0 +1,18 @@
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <misc/unique.hh>
+
+Test(unique_char, simple)
+{
+ misc::unique<char> the_answer = 'a';
+ misc::unique<char> the_same_answer = 'a';
+ misc::unique<char> the_solution = 'b';
+
+ cr_expect_eq(the_answer, misc::unique<char>('a'));
+ cr_expect_eq(the_answer, the_same_answer);
+ cr_expect_neq(the_answer, the_solution);
+
+ cr_expect_eq(the_answer.get(), the_same_answer.get());
+ cr_expect_eq(the_answer.get(), misc::unique<char>('a').get());
+ cr_expect_neq(the_answer.get(), the_solution.get());
+}
diff --git a/tiger-compiler/tests/unit/misc/unique/test_unique_int.cc b/tiger-compiler/tests/unit/misc/unique/test_unique_int.cc
new file mode 100644
index 0000000..f25c3c2
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/unique/test_unique_int.cc
@@ -0,0 +1,18 @@
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <misc/unique.hh>
+
+Test(unique_int, simple)
+{
+ misc::unique<int> the_answer = 42;
+ misc::unique<int> the_same_answer = 42;
+ misc::unique<int> the_solution = 51;
+
+ cr_expect_eq(the_answer, misc::unique<int>(42));
+ cr_expect_eq(the_answer, the_same_answer);
+ cr_expect_neq(the_answer, the_solution);
+
+ cr_expect_eq(the_answer.get(), the_same_answer.get());
+ cr_expect_eq(the_answer.get(), misc::unique<int>(42).get());
+ cr_expect_neq(the_answer.get(), the_solution.get());
+}
diff --git a/tiger-compiler/tests/unit/misc/unique/test_unique_string.cc b/tiger-compiler/tests/unit/misc/unique/test_unique_string.cc
new file mode 100644
index 0000000..2542375
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/unique/test_unique_string.cc
@@ -0,0 +1,19 @@
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <misc/unique.hh>
+#include <string>
+
+Test(unique_string, simple)
+{
+ misc::unique<std::string> the_answer = std::string("skibidi");
+ misc::unique<std::string> the_same_answer = std::string("skibidi");
+ misc::unique<std::string> the_solution = std::string("yes yes");
+
+ cr_expect_eq(the_answer, misc::unique<std::string>(std::string("skibidi")));
+ cr_expect_eq(the_answer, the_same_answer);
+ cr_expect_neq(the_answer, the_solution);
+
+ cr_expect_eq(the_answer.get(), the_same_answer.get());
+ cr_expect_eq(the_answer.get(), misc::unique<std::string>(std::string("skibidi")).get());
+ cr_expect_neq(the_answer.get(), the_solution.get());
+}
diff --git a/tiger-compiler/tests/unit/misc/variant/local.am b/tiger-compiler/tests/unit/misc/variant/local.am
new file mode 100644
index 0000000..f09d993
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/variant/local.am
@@ -0,0 +1,3 @@
+check_unit_SOURCES += \
+ %D%/test_variant_two_types.cc \
+ %D%/test_variant_three_types.cc
diff --git a/tiger-compiler/tests/unit/misc/variant/test_variant_three_types.cc b/tiger-compiler/tests/unit/misc/variant/test_variant_three_types.cc
new file mode 100644
index 0000000..8728059
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/variant/test_variant_three_types.cc
@@ -0,0 +1,35 @@
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <misc/variant.hh>
+
+using multiple_variant_type = misc::variant<int, std::string, double>;
+
+Test(variant_three_types, simple_success_type_a)
+{
+ multiple_variant_type v("Hello");
+ std::string s = v;
+ cr_expect_str_eq(s.c_str(), "Hello");
+}
+
+Test(variant_three_types, simple_success_type_b)
+{
+ multiple_variant_type v(56.7);
+ double d = v;
+ cr_expect_eq(d, 56.7);
+}
+
+Test(variant_three_types, simple_failure_type_c)
+{
+ multiple_variant_type v(34.5);
+
+ try
+ {
+ [[maybe_unused]] int i = v;
+ }
+ catch (const std::bad_variant_access& e)
+ {
+ return;
+ }
+
+ cr_expect_eq(1, 0, "copy assignment did not throw an exception");
+}
diff --git a/tiger-compiler/tests/unit/misc/variant/test_variant_two_types.cc b/tiger-compiler/tests/unit/misc/variant/test_variant_two_types.cc
new file mode 100644
index 0000000..9a63d6a
--- /dev/null
+++ b/tiger-compiler/tests/unit/misc/variant/test_variant_two_types.cc
@@ -0,0 +1,28 @@
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <misc/variant.hh>
+
+using variant_type = misc::variant<int, std::string>;
+
+Test(variant_two_types, simple_success)
+{
+ misc::variant<int, std::string> v("Hello");
+ std::string s = v;
+ cr_expect_str_eq(s.c_str(), "Hello");
+}
+
+Test(variant_two_types, simple_failure)
+{
+ variant_type v(42);
+
+ try
+ {
+ std::string s = v;
+ }
+ catch (const std::bad_variant_access& e)
+ {
+ return;
+ }
+
+ cr_expect_eq(1, 0, "copy assignment did not throw an exception");
+}
diff --git a/tiger-compiler/tests/unit/parse/local.am b/tiger-compiler/tests/unit/parse/local.am
new file mode 100644
index 0000000..2c9f827
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/local.am
@@ -0,0 +1,4 @@
+include %D%/tiger_driver/local.am
+include %D%/tiger_factory/local.am
+
+check_unit_SOURCES += %D%/test_hello.cc
diff --git a/tiger-compiler/tests/unit/parse/test_hello.cc b/tiger-compiler/tests/unit/parse/test_hello.cc
new file mode 100644
index 0000000..5828ca2
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/test_hello.cc
@@ -0,0 +1,36 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+Test(Basic, SimpleBody)
+{
+ std::cout << "----- basicTests -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* boiiiiiii = parse::parse("let "
+ " var i := 3 "
+ " in "
+ " i + 1 "
+ " end");
+ cr_assert_not_null(boiiiiiii);
+ print(boiiiiiii);
+ cr_assert_eq(1, 1);
+}
+
+Test(Basic, ChunkList)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("let "
+ " var i := 1 "
+ " var j := 2 "
+ " var k := 3 "
+ " in "
+ " i + j + k "
+ " end");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
diff --git a/tiger-compiler/tests/unit/parse/tiger_driver/local.am b/tiger-compiler/tests/unit/parse/tiger_driver/local.am
new file mode 100644
index 0000000..bd58ff7
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_driver/local.am
@@ -0,0 +1,2 @@
+check_unit_SOURCES += \
+ %D%/test_parse_no_check.cc
diff --git a/tiger-compiler/tests/unit/parse/tiger_driver/test_parse_no_check.cc b/tiger-compiler/tests/unit/parse/tiger_driver/test_parse_no_check.cc
new file mode 100644
index 0000000..81ebea2
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_driver/test_parse_no_check.cc
@@ -0,0 +1,19 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+
+Test(parse_no_check, simple)
+{
+ ast::Exp* e = parse::parse("a + b");
+}
+
+Test(parse_no_check, let_function)
+{
+ parse::parse("let"
+ "function f(a : int, b : string) : int = a"
+ "in"
+ "a"
+ "end");
+}
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/define_test_location.cc b/tiger-compiler/tests/unit/parse/tiger_factory/define_test_location.cc
new file mode 100644
index 0000000..71fd96b
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/define_test_location.cc
@@ -0,0 +1,5 @@
+#include "define_test_location.hh"
+
+#include <parse/tiger-factory.hh>
+
+parse::location test_l;
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/define_test_location.hh b/tiger-compiler/tests/unit/parse/tiger_factory/define_test_location.hh
new file mode 100644
index 0000000..f29ddae
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/define_test_location.hh
@@ -0,0 +1,5 @@
+#pragma once
+
+#include <parse/tiger-factory.hh>
+
+extern parse::location test_l;
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/local.am b/tiger-compiler/tests/unit/parse/tiger_factory/local.am
new file mode 100644
index 0000000..3c4bd9d
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/local.am
@@ -0,0 +1,12 @@
+check_unit_SOURCES += \
+ %D%/define_test_location.cc \
+ %D%/test_make_array_exp.cc \
+ %D%/test_make_break_exp.cc \
+ %D%/test_make_call_exp.cc \
+ %D%/test_make_field_var.cc \
+ %D%/test_make_if_exp.cc \
+ %D%/test_make_int_exp.cc \
+ %D%/test_make_let_exp.cc \
+ %D%/test_make_object_exp.cc \
+ %D%/test_make_record_ty.cc \
+ %D%/test_make_string_exp.cc
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_array_exp.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_array_exp.cc
new file mode 100644
index 0000000..949f92e
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_array_exp.cc
@@ -0,0 +1,30 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+TestSuite(BasicArr);
+
+Test(BasicArr, MakeArray)
+{
+ std::cout << "----- MakeArray -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("stuff[5] of 3");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+TestSuite(ExprsArr);
+
+Test(ExprsArr, MakeArray_WExprs)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("stuff[(36+6)] of \"Tiggered\"");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+} \ No newline at end of file
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_break_exp.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_break_exp.cc
new file mode 100644
index 0000000..02fb390
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_break_exp.cc
@@ -0,0 +1,30 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+TestSuite(BasicBrk);
+
+Test(BasicBrk, MakeBreak)
+{
+ std::cout << "----- Break -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("while (a < 5) do break");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+TestSuite(RealisticBrk);
+
+Test(RealisticBrk, MakeBetterBreak)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("while (a < 5) do (a := a + 1; break)");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+} \ No newline at end of file
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_call_exp.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_call_exp.cc
new file mode 100644
index 0000000..5c4b9bb
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_call_exp.cc
@@ -0,0 +1,41 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+TestSuite(BasicCall);
+
+Test(BasicCall, SimpleCall)
+{
+ std::cout << "----- FunCall -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("let "
+ " function test(a : int, b : string) : int = "
+ " a "
+ " in "
+ " test(1, \"2M, 22H->H, f.L, RS, RC, 55M, 632146M\") "
+ " end \n");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+TestSuite(RealisticCall);
+
+Test(RealisticCall, Call_WExprs)
+{
+ ast::PrettyPrinter print(std::cout);
+ // If someone get this and sends me a video proof, you have my utmost respect (the sequence in itself is not that hard tbh)
+ ast::Exp* test = parse::parse("let "
+ " function test(a : int, b : string) : int = "
+ " a "
+ " in "
+ " test(1 + 2 + c + inexistant, \"2M, 22H->H, f.L, RS, RC, 55M, 632146M\")"
+ " end \n");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_field_var.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_field_var.cc
new file mode 100644
index 0000000..1d85afa
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_field_var.cc
@@ -0,0 +1,30 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+TestSuite(BasicVar);
+
+Test(BasicVar, SimpleVar)
+{
+ std::cout << "----- BaseVars -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("var test := \"Code harder, not smarter\"");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+TestSuite(RealisticVar);
+
+Test(RealisticVar, Var_WExprs)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("var test : int := 3 + 6 + 9");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+} \ No newline at end of file
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_if_exp.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_if_exp.cc
new file mode 100644
index 0000000..d324591
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_if_exp.cc
@@ -0,0 +1,48 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+TestSuite(BasicIf);
+
+Test(BasicIf, OnlyIf)
+{
+ std::cout << "----- IfLoops -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("if a > 5 then a");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+TestSuite(RealisticIf);
+
+Test(RealisticIf, IfElse)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("if a > 5 then a else b");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+Test(RealisticIf, IfsElses)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("if a > 5 then a else if a < 0 then b else c");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+Test(RealisticIf, DanglingElse)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("if a > 5 then if a < 0 then b else c else d");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+} \ No newline at end of file
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_int_exp.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_int_exp.cc
new file mode 100644
index 0000000..01a5f97
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_int_exp.cc
@@ -0,0 +1,38 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+TestSuite(BasicInt);
+
+Test(BasicInt, SimpleVal)
+{
+ std::cout << "----- MakeInt -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("215");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+Test(BasicInt, SimpleUnaryVal)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("-215");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+TestSuite(RealisticInt);
+
+Test(RealisticInt, Exception)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("2147483648");
+ cr_assert_null(test);
+ cr_assert_eq(1, 1);
+} \ No newline at end of file
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_let_exp.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_let_exp.cc
new file mode 100644
index 0000000..b88bd76
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_let_exp.cc
@@ -0,0 +1,30 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+TestSuite(BasicLet);
+
+Test(BasicLet, SimpleLet)
+{
+ std::cout << "----- SimpleLet -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("let function test(a : int) : int = a in end");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+TestSuite(RealisticLet);
+
+Test(RealisticLet, StuffedLet)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("let function test(a : int) : int = a var b := 84 type badaboum = array of int in test(b) end");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+} \ No newline at end of file
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_object_exp.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_object_exp.cc
new file mode 100644
index 0000000..f80dc75
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_object_exp.cc
@@ -0,0 +1,19 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+Test(make_object_exp, simple)
+{
+ std::cout << "----- SimpleObject -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("class test extends bobby { "
+ " var field := 5 "
+ " method maths(a : int) : int = a }", true);
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+} \ No newline at end of file
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_record_exp.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_record_exp.cc
new file mode 100644
index 0000000..7ffc23a
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_record_exp.cc
@@ -0,0 +1,30 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+TestSuite(BasicRec);
+
+Test(BasicRec, SimpleRec)
+{
+ std::cout << "----- BaseRec -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("pair = {value : int, key : string}");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+TestSuite(RealisticRec);
+
+Test(RealisticRec, RecRec)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("node = {value : int, next : node}");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+} \ No newline at end of file
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_record_ty.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_record_ty.cc
new file mode 100644
index 0000000..fcea129
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_record_ty.cc
@@ -0,0 +1,30 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+TestSuite(BasicRecTy);
+
+Test(BasicRecTy, SimpleTy)
+{
+ std::cout << "----- BaseTyRec -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("type pair = {value : int, key : string}");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+TestSuite(RealisticRecTy);
+
+Test(RealisticRecTy, RecTy)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("type node = {value : int, next : node}");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+} \ No newline at end of file
diff --git a/tiger-compiler/tests/unit/parse/tiger_factory/test_make_string_exp.cc b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_string_exp.cc
new file mode 100644
index 0000000..2b898b0
--- /dev/null
+++ b/tiger-compiler/tests/unit/parse/tiger_factory/test_make_string_exp.cc
@@ -0,0 +1,30 @@
+#include <ast/exp.hh>
+#include <ast/libast.hh>
+#include <criterion/criterion.h>
+#include <criterion/assert.h>
+#include <parse/libparse.hh>
+#include <ast/fwd.hh>
+#include <ast/pretty-printer.hh>
+
+TestSuite(BasicStr);
+
+Test(BasicStr, SimpleStr)
+{
+ std::cout << "----- BaseTyRec -----";
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("Screw gravity!");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+}
+
+TestSuite(RealisticStr);
+
+Test(RealisticStr, Escapes)
+{
+ ast::PrettyPrinter print(std::cout);
+ ast::Exp* test = parse::parse("Something's wrong \\\"\n, I can feel it...\r");
+ cr_assert_not_null(test);
+ print(test);
+ cr_assert_eq(1, 1);
+} \ No newline at end of file
diff --git a/tiger-compiler/tests/unit/tasks/bind/local.am b/tiger-compiler/tests/unit/tasks/bind/local.am
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/tiger-compiler/tests/unit/tasks/bind/local.am
diff --git a/tiger-compiler/tests/unit/tasks/local.am b/tiger-compiler/tests/unit/tasks/local.am
new file mode 100644
index 0000000..eca6000
--- /dev/null
+++ b/tiger-compiler/tests/unit/tasks/local.am
@@ -0,0 +1 @@
+include %D%/bind/local.am