summaryrefslogtreecommitdiff
path: root/test/buildtool/build_engine/expression/expression.test.cpp
diff options
context:
space:
mode:
authorKlaus Aehlig <klaus.aehlig@huawei.com>2024-04-22 10:48:46 +0200
committerKlaus Aehlig <klaus.aehlig@huawei.com>2024-04-24 12:30:09 +0200
commit14b93071eca21c69b635bd77eb68057b2906ddab (patch)
tree324d82d99e9015239f548acf17e1e9373af1f65a /test/buildtool/build_engine/expression/expression.test.cpp
parent199487b5ba387653bbec36d6dcea85819c90994c (diff)
downloadjustbuild-14b93071eca21c69b635bd77eb68057b2906ddab.tar.gz
expressions: add "length" function
Lists are somtimes used in configurations as replacement for tuples. Providing length gives an easy way to detect usage errors.
Diffstat (limited to 'test/buildtool/build_engine/expression/expression.test.cpp')
-rw-r--r--test/buildtool/build_engine/expression/expression.test.cpp13
1 files changed, 13 insertions, 0 deletions
diff --git a/test/buildtool/build_engine/expression/expression.test.cpp b/test/buildtool/build_engine/expression/expression.test.cpp
index 18189baf..83550ebd 100644
--- a/test/buildtool/build_engine/expression/expression.test.cpp
+++ b/test/buildtool/build_engine/expression/expression.test.cpp
@@ -1010,6 +1010,19 @@ TEST_CASE("Expression Evaluation", "[expression]") { // NOLINT
)"_json));
}
+ SECTION("length expression") {
+ auto expr = Expression::FromJson(R"(
+ { "type": "length"
+ , "$1": ["foo", "bar", "baz"]
+ }
+ )"_json);
+ REQUIRE(expr);
+
+ auto result = expr.Evaluate(env, fcts);
+ REQUIRE(result);
+ CHECK(result == Expression::FromJson("3"_json));
+ }
+
SECTION("keys expression") {
auto expr = Expression::FromJson(R"(
{ "type": "keys"