aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src/vcpkg-test/platform-expression.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'toolsrc/src/vcpkg-test/platform-expression.cpp')
-rw-r--r--toolsrc/src/vcpkg-test/platform-expression.cpp80
1 files changed, 0 insertions, 80 deletions
diff --git a/toolsrc/src/vcpkg-test/platform-expression.cpp b/toolsrc/src/vcpkg-test/platform-expression.cpp
deleted file mode 100644
index aef999230..000000000
--- a/toolsrc/src/vcpkg-test/platform-expression.cpp
+++ /dev/null
@@ -1,80 +0,0 @@
-#include <catch2/catch.hpp>
-
-#include <vcpkg/platform-expression.h>
-
-using vcpkg::StringView;
-using namespace vcpkg::PlatformExpression;
-
-static vcpkg::ExpectedS<Expr> parse_expr(StringView s)
-{
- return parse_platform_expression(s, MultipleBinaryOperators::Deny);
-}
-
-TEST_CASE ("platform-expression-identifier", "[platform-expression]")
-{
- auto m_expr = parse_expr("windows");
- REQUIRE(m_expr);
- auto& expr = *m_expr.get();
-
- CHECK(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", ""}}));
- CHECK(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", "WindowsStore"}}));
- CHECK_FALSE(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", "Linux"}}));
- CHECK_FALSE(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", "Darwin"}}));
-}
-
-TEST_CASE ("platform-expression-not", "[platform-expression]")
-{
- auto m_expr = parse_expr("!windows");
- REQUIRE(m_expr);
- auto& expr = *m_expr.get();
-
- CHECK_FALSE(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", ""}}));
- CHECK_FALSE(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", "WindowsStore"}}));
- CHECK(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", "Linux"}}));
- CHECK(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", "Darwin"}}));
-}
-
-TEST_CASE ("platform-expression-and", "[platform-expression]")
-{
- auto m_expr = parse_expr("!windows & !arm");
- REQUIRE(m_expr);
- auto& expr = *m_expr.get();
-
- CHECK_FALSE(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", ""}}));
- CHECK_FALSE(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", "WindowsStore"}}));
- CHECK(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", "Linux"}}));
- CHECK_FALSE(expr.evaluate({
- {"VCPKG_CMAKE_SYSTEM_NAME", "Linux"},
- {"VCPKG_TARGET_ARCHITECTURE", "arm"},
- }));
-}
-
-TEST_CASE ("platform-expression-or", "[platform-expression]")
-{
- auto m_expr = parse_expr("!windows | arm");
- REQUIRE(m_expr);
- auto& expr = *m_expr.get();
-
- CHECK_FALSE(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", ""}}));
- CHECK(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", ""}, {"VCPKG_TARGET_ARCHITECTURE", "arm"}}));
- CHECK(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", "Linux"}}));
-}
-
-TEST_CASE ("weird platform-expressions whitespace", "[platform-expression]")
-{
- auto m_expr = parse_expr(" ! \t windows \n| arm \r");
- REQUIRE(m_expr);
- auto& expr = *m_expr.get();
-
- CHECK_FALSE(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", ""}}));
- CHECK(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", ""}, {"VCPKG_TARGET_ARCHITECTURE", "arm"}}));
- CHECK(expr.evaluate({{"VCPKG_CMAKE_SYSTEM_NAME", "Linux"}}));
-}
-
-TEST_CASE ("no mixing &, | in platform expressions", "[platform-expression]")
-{
- auto m_expr = parse_expr("windows & arm | linux");
- CHECK_FALSE(m_expr);
- m_expr = parse_expr("windows | !arm & linux");
- CHECK_FALSE(m_expr);
-}