summaryrefslogtreecommitdiff
path: root/test/gtest
diff options
context:
space:
mode:
authorThomas Lively <tlively@google.com>2023-10-25 20:19:30 +0200
committerGitHub <noreply@github.com>2023-10-25 20:19:30 +0200
commit2b6566341cf316cc18486e96d54e8d8dd9a57a5b (patch)
tree8a9746fc0a59535af5188ee66dcf077dd259f32b /test/gtest
parent9af7abd106e6e1b1dccdd70125a761b385f653d8 (diff)
downloadbinaryen-2b6566341cf316cc18486e96d54e8d8dd9a57a5b.tar.gz
binaryen-2b6566341cf316cc18486e96d54e8d8dd9a57a5b.tar.bz2
binaryen-2b6566341cf316cc18486e96d54e8d8dd9a57a5b.zip
[analysis] Implement a Bool lattice (#6036)
This is a lattice with two elements: `false` is bottom and `true` is top. Add a new gtest file for testing lattices.
Diffstat (limited to 'test/gtest')
-rw-r--r--test/gtest/CMakeLists.txt1
-rw-r--r--test/gtest/lattices.cpp50
2 files changed, 51 insertions, 0 deletions
diff --git a/test/gtest/CMakeLists.txt b/test/gtest/CMakeLists.txt
index d50d33ac1..b40130760 100644
--- a/test/gtest/CMakeLists.txt
+++ b/test/gtest/CMakeLists.txt
@@ -4,6 +4,7 @@ include_directories(../../src/wasm)
set(unittest_SOURCES
cfg.cpp
dfa_minimization.cpp
+ lattices.cpp
possible-contents.cpp
printing.cpp
stringify.cpp
diff --git a/test/gtest/lattices.cpp b/test/gtest/lattices.cpp
new file mode 100644
index 000000000..f06ba612b
--- /dev/null
+++ b/test/gtest/lattices.cpp
@@ -0,0 +1,50 @@
+/*
+ * Copyright 2023 WebAssembly Community Group participants
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "analysis/lattices/bool.h"
+#include "gtest/gtest.h"
+
+using namespace wasm;
+
+TEST(BoolLattice, GetBottom) {
+ analysis::Bool lattice;
+ EXPECT_FALSE(lattice.getBottom());
+}
+
+TEST(BoolLattice, Compare) {
+ analysis::Bool lattice;
+ EXPECT_EQ(lattice.compare(false, false), analysis::EQUAL);
+ EXPECT_EQ(lattice.compare(false, true), analysis::LESS);
+ EXPECT_EQ(lattice.compare(true, false), analysis::GREATER);
+ EXPECT_EQ(lattice.compare(true, true), analysis::EQUAL);
+}
+
+TEST(BoolLattice, Join) {
+ analysis::Bool lattice;
+ bool elem = false;
+
+ EXPECT_FALSE(lattice.join(elem, false));
+ ASSERT_FALSE(elem);
+
+ EXPECT_TRUE(lattice.join(elem, true));
+ ASSERT_TRUE(elem);
+
+ EXPECT_FALSE(lattice.join(elem, false));
+ ASSERT_TRUE(elem);
+
+ EXPECT_FALSE(lattice.join(elem, true));
+ ASSERT_TRUE(elem);
+}