summaryrefslogtreecommitdiff
path: root/test/buildtool/build_engine/base_maps/expression_map.test.cpp
diff options
context:
space:
mode:
authorKlaus Aehlig <klaus.aehlig@huawei.com>2022-02-22 17:03:21 +0100
committerKlaus Aehlig <klaus.aehlig@huawei.com>2022-02-22 17:03:21 +0100
commit619def44c1cca9f3cdf63544d5f24f2c7a7d9b77 (patch)
tree01868de723cb82c86842f33743fa7b14e24c1fa3 /test/buildtool/build_engine/base_maps/expression_map.test.cpp
downloadjustbuild-619def44c1cca9f3cdf63544d5f24f2c7a7d9b77.tar.gz
Initial self-hosting commit
This is the initial version of our tool that is able to build itself. In can be bootstrapped by ./bin/bootstrap.py Co-authored-by: Oliver Reiche <oliver.reiche@huawei.com> Co-authored-by: Victor Moreno <victor.moreno1@huawei.com>
Diffstat (limited to 'test/buildtool/build_engine/base_maps/expression_map.test.cpp')
-rw-r--r--test/buildtool/build_engine/base_maps/expression_map.test.cpp208
1 files changed, 208 insertions, 0 deletions
diff --git a/test/buildtool/build_engine/base_maps/expression_map.test.cpp b/test/buildtool/build_engine/base_maps/expression_map.test.cpp
new file mode 100644
index 00000000..e8068475
--- /dev/null
+++ b/test/buildtool/build_engine/base_maps/expression_map.test.cpp
@@ -0,0 +1,208 @@
+#include <filesystem>
+#include <functional>
+
+#include "catch2/catch.hpp"
+#include "src/buildtool/build_engine/base_maps/expression_map.hpp"
+#include "src/buildtool/build_engine/base_maps/json_file_map.hpp"
+#include "src/buildtool/common/repository_config.hpp"
+#include "src/buildtool/multithreading/task_system.hpp"
+#include "test/buildtool/build_engine/base_maps/test_repo.hpp"
+
+namespace {
+
+using namespace BuildMaps::Base; // NOLINT
+
+void SetupConfig(bool use_git) {
+ auto root = FileRoot{kBasePath / "data_expr"};
+ if (use_git) {
+ auto repo_path = CreateTestRepo();
+ REQUIRE(repo_path);
+ auto git_root = FileRoot::FromGit(*repo_path, kExprTreeId);
+ REQUIRE(git_root);
+ root = std::move(*git_root);
+ }
+ RepositoryConfig::Instance().Reset();
+ RepositoryConfig::Instance().SetInfo(
+ "", RepositoryConfig::RepositoryInfo{root});
+}
+
+auto ReadExpressionFunction(EntityName const& id,
+ ExpressionFunctionMap::Consumer value_checker,
+ bool use_git = false) -> bool {
+ SetupConfig(use_git);
+ auto expr_file_map = CreateExpressionFileMap(0);
+ auto expr_func_map = CreateExpressionMap(&expr_file_map);
+
+ bool success{true};
+ {
+ TaskSystem ts;
+ expr_func_map.ConsumeAfterKeysReady(
+ &ts,
+ {id},
+ std::move(value_checker),
+ [&success](std::string const& /*unused*/, bool /*unused*/) {
+ success = false;
+ });
+ }
+ return success;
+}
+
+} // namespace
+
+TEST_CASE("Simple expression object literal", "[expression_map]") {
+ auto name = EntityName{"", ".", "test_expression_literal"};
+ auto consumer = [](auto values) {
+ REQUIRE(*values[0]);
+ auto expr = (*values[0])->Evaluate({}, {});
+
+ REQUIRE(expr);
+ REQUIRE(expr->IsString());
+ CHECK(expr == Expression::FromJson(R"("foo")"_json));
+ };
+
+ SECTION("via file") {
+ CHECK(ReadExpressionFunction(name, consumer, /*use_git=*/false));
+ }
+
+ SECTION("via git tree") {
+ CHECK(ReadExpressionFunction(name, consumer, /*use_git=*/true));
+ }
+}
+
+TEST_CASE("Simple read of variable", "[expression_map]") {
+ auto name = EntityName{"", ".", "test_read_vars"};
+ auto consumer = [](auto values) {
+ REQUIRE(*values[0]);
+ auto expr = (*values[0])
+ ->Evaluate(Configuration{Expression::FromJson(
+ R"({"FOO": "bar"})"_json)},
+ {});
+
+ REQUIRE(expr);
+ REQUIRE(expr->IsString());
+ CHECK(expr == Expression{std::string{"bar"}});
+ };
+
+ SECTION("via file") {
+ CHECK(ReadExpressionFunction(name, consumer, /*use_git=*/false));
+ }
+
+ SECTION("via git tree") {
+ CHECK(ReadExpressionFunction(name, consumer, /*use_git=*/true));
+ }
+}
+
+TEST_CASE("Simple call of imported expression", "[expression_map]") {
+ auto name = EntityName{"", ".", "test_call_import"};
+ auto consumer = [](auto values) {
+ REQUIRE(*values[0]);
+ auto expr = (*values[0])
+ ->Evaluate(Configuration{Expression::FromJson(
+ R"({"FOO": "bar"})"_json)},
+ {});
+
+ REQUIRE(expr);
+ REQUIRE(expr->IsString());
+ CHECK(expr == Expression{std::string{"bar"}});
+ };
+
+ SECTION("via file") {
+ CHECK(ReadExpressionFunction(name, consumer, /*use_git=*/false));
+ }
+
+ SECTION("via git tree") {
+ CHECK(ReadExpressionFunction(name, consumer, /*use_git=*/true));
+ }
+}
+
+TEST_CASE("Overwrite import in nested expression", "[expression_map]") {
+ auto name = EntityName{"", ".", "test_overwrite_import"};
+ auto consumer = [](auto values) {
+ REQUIRE(*values[0]);
+ auto expr = (*values[0])
+ ->Evaluate(Configuration{Expression::FromJson(
+ R"({"FOO": "bar"})"_json)},
+ {});
+
+ REQUIRE(expr);
+ REQUIRE(expr->IsString());
+ CHECK(expr == Expression{std::string{"bar"}});
+ };
+
+ SECTION("via file") {
+ CHECK(ReadExpressionFunction(name, consumer, /*use_git=*/false));
+ }
+
+ SECTION("via git tree") {
+ CHECK(ReadExpressionFunction(name, consumer, /*use_git=*/true));
+ }
+}
+
+TEST_CASE("Fail due to unkown ID", "[expression_map]") {
+ auto name = EntityName{"", ".", "does_not_exist"};
+ auto consumer = [](auto /*values*/) {
+ CHECK(false); // should never be called
+ };
+
+ SECTION("via file") {
+ CHECK_FALSE(ReadExpressionFunction(name, consumer, /*use_git=*/false));
+ }
+
+ SECTION("via git tree") {
+ CHECK_FALSE(ReadExpressionFunction(name, consumer, /*use_git=*/true));
+ }
+}
+
+TEST_CASE("Fail due to missing vars", "[expression_map]") {
+ CHECK(
+ ReadExpressionFunction({"", ".", "test_missing_vars"}, [](auto values) {
+ REQUIRE(*values[0]);
+ auto expr = (*values[0])
+ ->Evaluate(Configuration{Expression::FromJson(
+ R"({"FOO": "bar"})"_json)},
+ {});
+
+ CHECK(expr == Expression::FromJson(R"(null)"_json));
+ }));
+}
+
+TEST_CASE("Fail due to missing imports", "[expression_map]") {
+ CHECK(ReadExpressionFunction(
+ {"", ".", "test_missing_imports"}, [](auto values) {
+ REQUIRE(*values[0]);
+ auto expr = (*values[0])
+ ->Evaluate(Configuration{Expression::FromJson(
+ R"({"FOO": "bar"})"_json)},
+ {});
+
+ CHECK_FALSE(expr);
+ }));
+}
+
+TEST_CASE("Malformed function", "[expression_map]") {
+ CHECK_FALSE(ReadExpressionFunction(
+ {"", ".", "test_malformed_function"}, [](auto /*values*/) {
+ CHECK(false); // should never be called
+ }));
+}
+
+TEST_CASE("Malformed expression", "[expression_map]") {
+ CHECK_FALSE(ReadExpressionFunction(
+ {"", ".", "test_malformed_expression"}, [](auto /*values*/) {
+ CHECK(false); // should never be called
+ }));
+}
+
+TEST_CASE("Malformed vars", "[expression_map]") {
+ CHECK_FALSE(ReadExpressionFunction(
+ {"", ".", "test_malformed_vars"}, [](auto /*values*/) {
+ CHECK(false); // should never be called
+ }));
+}
+
+TEST_CASE("Malformed imports", "[expression_map]") {
+ CHECK_FALSE(ReadExpressionFunction(
+ {"", ".", "test_malformed_imports"}, [](auto /*values*/) {
+ CHECK(false); // should never be called
+ }));
+}