mirror of
https://github.com/NixOS/nix.git
synced 2025-11-27 12:41:00 +01:00
* It is tough to contribute to a project that doesn't use a formatter, * It is extra hard to contribute to a project which has configured the formatter, but ignores it for some files * Code formatting makes it harder to hide obscure / weird bugs by accident or on purpose, Let's rip the bandaid off? Note that PRs currently in flight should be able to be merged relatively easily by applying `clang-format` to their tip prior to merge. Co-authored-by: Graham Christensen <graham@grahamc.com>
68 lines
1.8 KiB
C++
68 lines
1.8 KiB
C++
#include "nix/util/closure.hh"
|
|
#include <gtest/gtest.h>
|
|
|
|
namespace nix {
|
|
|
|
using namespace std;
|
|
|
|
map<string, set<string>> testGraph = {
|
|
{"A", {"B", "C", "G"}},
|
|
{"B", {"A"}}, // Loops back to A
|
|
{"C", {"F"}}, // Indirect reference
|
|
{"D", {"A"}}, // Not reachable, but has backreferences
|
|
{"E", {}}, // Just not reachable
|
|
{"F", {}},
|
|
{"G", {"G"}}, // Self reference
|
|
};
|
|
|
|
TEST(closure, correctClosure)
|
|
{
|
|
set<string> aClosure;
|
|
set<string> expectedClosure = {"A", "B", "C", "F", "G"};
|
|
computeClosure<string>(
|
|
{"A"}, aClosure, [&](const string currentNode, function<void(promise<set<string>> &)> processEdges) {
|
|
promise<set<string>> promisedNodes;
|
|
promisedNodes.set_value(testGraph[currentNode]);
|
|
processEdges(promisedNodes);
|
|
});
|
|
|
|
ASSERT_EQ(aClosure, expectedClosure);
|
|
}
|
|
|
|
TEST(closure, properlyHandlesDirectExceptions)
|
|
{
|
|
struct TestExn
|
|
{};
|
|
|
|
set<string> aClosure;
|
|
EXPECT_THROW(
|
|
computeClosure<string>(
|
|
{"A"},
|
|
aClosure,
|
|
[&](const string currentNode, function<void(promise<set<string>> &)> processEdges) { throw TestExn(); }),
|
|
TestExn);
|
|
}
|
|
|
|
TEST(closure, properlyHandlesExceptionsInPromise)
|
|
{
|
|
struct TestExn
|
|
{};
|
|
|
|
set<string> aClosure;
|
|
EXPECT_THROW(
|
|
computeClosure<string>(
|
|
{"A"},
|
|
aClosure,
|
|
[&](const string currentNode, function<void(promise<set<string>> &)> processEdges) {
|
|
promise<set<string>> promise;
|
|
try {
|
|
throw TestExn();
|
|
} catch (...) {
|
|
promise.set_exception(std::current_exception());
|
|
}
|
|
processEdges(promise);
|
|
}),
|
|
TestExn);
|
|
}
|
|
|
|
} // namespace nix
|