Skip to content

Commit

Permalink
feat(tests): adding first test for IR generation and optimization
Browse files Browse the repository at this point in the history
  • Loading branch information
SuperFola committed Nov 1, 2024
1 parent 35f0968 commit 2556ebd
Show file tree
Hide file tree
Showing 4 changed files with 84 additions and 1 deletion.
25 changes: 25 additions & 0 deletions tests/unittests/CompilerSuite.cpp
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
#include <boost/ut.hpp>

#include <Ark/Compiler/Welder.hpp>
#include <Ark/Compiler/Word.hpp>

#include "TestsHelper.hpp"

using namespace boost;

ut::suite<"Compiler"> compiler_suite = [] {
Expand Down Expand Up @@ -34,4 +37,26 @@ ut::suite<"Compiler"> compiler_suite = [] {
expect(that % secondary_arg == ((padding << 4) | (arg & 0xf000) >> 12));
};
};

"IR generation and optimization"_test = [] {
constexpr uint16_t features = Ark::DefaultFeatures | Ark::FeatureTestFailOnException;

iter_test_files(
"CompilerSuite/ir",
[](TestData&& data) {
Ark::Welder welder(0, { std::filesystem::path(ARK_TESTS_ROOT "/lib/") }, features);

should("compile without error ir/" + data.stem) = [&] {
expect(mut(welder).computeASTFromFile(data.path));
expect(mut(welder).generateBytecode());
};

should("output expected IR for " + data.stem) = [&] {
std::string ir = welder.textualIR();

ltrim(rtrim(ir));
expect(that % ir == data.expected);
};
});
};
};
2 changes: 1 addition & 1 deletion tests/unittests/TestsHelper.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ std::string get_resource_path(const std::string& folder)
return (ARK_TESTS_ROOT "tests/unittests/resources/") + folder;
}

std::string sanitize_error(const Ark::CodeError& e, bool remove_in_file_line)
std::string sanitize_error(const Ark::CodeError& e, const bool remove_in_file_line)
{
std::stringstream stream;
Ark::Diagnostics::generate(e, stream, /* colorize= */ false);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
# the Ackermann Peter function (see https://en.wikipedia.org/wiki/Ackermann_function)
# One of the simplest and earliest-discovered examples of a total computable function,
# that is not primitive. All primitive recursive functions are total and computable,
# but the Ackermann function illustrates that not all total computable functions
# are primitive recursive.
# Due to its definitions in terms of extremely deep recursion, it can be used as a
# benchmark of a compiler's ability to optimize recursion, which is the reason why
# we are using this function to benchmark the language.
(let ackermann (fun (m n) {
(if (> m 0)
# then
(if (= 0 n)
# then
(ackermann (- m 1) 1)
# else
(ackermann (- m 1) (ackermann m (- n 1))))
# else
(+ 1 n)) }))

(print "Ackermann-Péter function, m=3, n=6: " (ackermann 3 6))
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
page_0
LOAD_CONST_STORE 0, 0
LOAD_CONST_LOAD_CONST 3, 4
LOAD_CONST 5
LOAD_SYMBOL 0
CALL 2
CALL_BUILTIN 9, 2
HALT 0

page_1
STORE 1
STORE 2
LOAD_SYMBOL 1
LOAD_CONST 1
GT 0
GOTO_IF_TRUE L0
INCREMENT 2
GOTO L1
.L0:
LOAD_CONST 1
LOAD_SYMBOL 2
EQ 0
GOTO_IF_TRUE L2
LOAD_SYMBOL 1
DECREMENT 2
LOAD_SYMBOL 0
CALL 2
DECREMENT 1
JUMP 0
GOTO L3
.L2:
LOAD_CONST 2
DECREMENT 1
JUMP 0
.L3:
.L1:
RET 0
HALT 0

0 comments on commit 2556ebd

Please sign in to comment.