blob: 7eeb8fdc237513b55f532816682e5cbd4c1fcb2f [file] [log] [blame] [edit]
/*
* Copyright 2024 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 <cstddef>
#include <optional>
#include <vector>
#include "support/topological_orders.h"
#include "gtest/gtest.h"
using namespace wasm;
using Graph = std::vector<std::vector<size_t>>;
TEST(TopologicalOrdersTest, Empty) {
Graph graph;
TopologicalOrders orders(graph);
EXPECT_EQ(orders.begin(), orders.end());
}
TEST(TopologicalOrdersTest, Singleton) {
Graph graph(1);
TopologicalOrders orders(graph);
auto it = orders.begin();
ASSERT_NE(it, orders.end());
EXPECT_EQ(*it, std::vector<size_t>{0});
++it;
EXPECT_EQ(it, orders.end());
}
TEST(TopologicalOrdersTest, Permutations) {
Graph graph(3);
TopologicalOrders orders(graph);
std::set<std::vector<size_t>> results(orders.begin(), orders.end());
std::set<std::vector<size_t>> expected{
{0, 1, 2},
{0, 2, 1},
{1, 0, 2},
{1, 2, 0},
{2, 0, 1},
{2, 1, 0},
};
EXPECT_EQ(results, expected);
}
TEST(TopologicalOrdersTest, Chain) {
constexpr size_t n = 10;
Graph graph(n);
for (size_t i = 1; i < n; ++i) {
graph[i].push_back(i - 1);
}
TopologicalOrders orders(graph);
std::set<std::vector<size_t>> results(orders.begin(), orders.end());
std::set<std::vector<size_t>> expected{{9, 8, 7, 6, 5, 4, 3, 2, 1, 0}};
EXPECT_EQ(results, expected);
}
TEST(TopologicalOrdersTest, TwoChains) {
Graph graph(4);
graph[0].push_back(2);
graph[1].push_back(3);
TopologicalOrders orders(graph);
std::set<std::vector<size_t>> results(orders.begin(), orders.end());
std::set<std::vector<size_t>> expected{
{0, 1, 2, 3},
{0, 1, 3, 2},
{0, 2, 1, 3},
{1, 0, 2, 3},
{1, 0, 3, 2},
{1, 3, 0, 2},
};
EXPECT_EQ(results, expected);
}
TEST(TopologicalOrdersTest, Diamond) {
Graph graph(4);
graph[0].push_back(1);
graph[0].push_back(2);
graph[1].push_back(3);
graph[2].push_back(3);
TopologicalOrders orders(graph);
std::set<std::vector<size_t>> results(orders.begin(), orders.end());
std::set<std::vector<size_t>> expected{
{0, 1, 2, 3},
{0, 2, 1, 3},
};
EXPECT_EQ(results, expected);
}