diff options
| author | 2020-08-03 15:06:44 +0000 | |
|---|---|---|
| committer | 2020-08-03 15:06:44 +0000 | |
| commit | b64793999546ed8adebaeebd9d8345d18db8927d (patch) | |
| tree | 4357c27b561d73b0e089727c6ed659f2ceff5f47 /gnu/llvm/unittests/ExecutionEngine/Orc/LegacyAPIInteropTest.cpp | |
| parent | Add support for UTF-8 DISPLAY-HINTs with octet length. For now only (diff) | |
| download | wireguard-openbsd-b64793999546ed8adebaeebd9d8345d18db8927d.tar.xz wireguard-openbsd-b64793999546ed8adebaeebd9d8345d18db8927d.zip | |
Remove LLVM 8.0.1 files.
Diffstat (limited to 'gnu/llvm/unittests/ExecutionEngine/Orc/LegacyAPIInteropTest.cpp')
| -rw-r--r-- | gnu/llvm/unittests/ExecutionEngine/Orc/LegacyAPIInteropTest.cpp | 133 |
1 files changed, 0 insertions, 133 deletions
diff --git a/gnu/llvm/unittests/ExecutionEngine/Orc/LegacyAPIInteropTest.cpp b/gnu/llvm/unittests/ExecutionEngine/Orc/LegacyAPIInteropTest.cpp deleted file mode 100644 index 36cb7102623..00000000000 --- a/gnu/llvm/unittests/ExecutionEngine/Orc/LegacyAPIInteropTest.cpp +++ /dev/null @@ -1,133 +0,0 @@ -//===----------- CoreAPIsTest.cpp - Unit tests for Core ORC APIs ----------===// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// - -#include "OrcTestCommon.h" -#include "llvm/ExecutionEngine/Orc/Legacy.h" -#include "gtest/gtest.h" - -using namespace llvm; -using namespace llvm::orc; - -class LegacyAPIsStandardTest : public CoreAPIsBasedStandardTest {}; - -namespace { - -TEST_F(LegacyAPIsStandardTest, TestLambdaSymbolResolver) { - BarSym.setFlags(BarSym.getFlags() | JITSymbolFlags::Weak); - - cantFail(JD.define(absoluteSymbols({{Foo, FooSym}, {Bar, BarSym}}))); - - auto Resolver = createSymbolResolver( - [&](const SymbolNameSet &Symbols) { - auto FlagsMap = JD.lookupFlags(Symbols); - SymbolNameSet Result; - for (auto &KV : FlagsMap) - if (!KV.second.isStrong()) - Result.insert(KV.first); - return Result; - }, - [&](std::shared_ptr<AsynchronousSymbolQuery> Q, SymbolNameSet Symbols) { - return JD.legacyLookup(std::move(Q), Symbols); - }); - - auto RS = Resolver->getResponsibilitySet(SymbolNameSet({Bar, Baz})); - - EXPECT_EQ(RS.size(), 1U) - << "getResponsibilitySet returned the wrong number of results"; - EXPECT_EQ(RS.count(Bar), 1U) - << "getResponsibilitySet result incorrect. Should be {'bar'}"; - - bool OnResolvedRun = false; - - auto OnResolved = [&](Expected<SymbolMap> Result) { - OnResolvedRun = true; - EXPECT_TRUE(!!Result) << "Unexpected error"; - EXPECT_EQ(Result->size(), 2U) << "Unexpected number of resolved symbols"; - EXPECT_EQ(Result->count(Foo), 1U) << "Missing lookup result for foo"; - EXPECT_EQ(Result->count(Bar), 1U) << "Missing lookup result for bar"; - EXPECT_EQ((*Result)[Foo].getAddress(), FooSym.getAddress()) - << "Incorrect address for foo"; - EXPECT_EQ((*Result)[Bar].getAddress(), BarSym.getAddress()) - << "Incorrect address for bar"; - }; - auto OnReady = [&](Error Err) { - EXPECT_FALSE(!!Err) << "Finalization should never fail in this test"; - }; - - auto Q = std::make_shared<AsynchronousSymbolQuery>(SymbolNameSet({Foo, Bar}), - OnResolved, OnReady); - auto Unresolved = - Resolver->lookup(std::move(Q), SymbolNameSet({Foo, Bar, Baz})); - - EXPECT_EQ(Unresolved.size(), 1U) << "Expected one unresolved symbol"; - EXPECT_EQ(Unresolved.count(Baz), 1U) << "Expected baz to not be resolved"; - EXPECT_TRUE(OnResolvedRun) << "OnResolved was never run"; -} - -TEST_F(LegacyAPIsStandardTest, LegacyLookupHelpersFn) { - bool BarMaterialized = false; - BarSym.setFlags(BarSym.getFlags() | JITSymbolFlags::Weak); - - auto LegacyLookup = [&](const std::string &Name) -> JITSymbol { - if (Name == "foo") - return FooSym; - - if (Name == "bar") { - auto BarMaterializer = [&]() -> Expected<JITTargetAddress> { - BarMaterialized = true; - return BarAddr; - }; - - return {BarMaterializer, BarSym.getFlags()}; - } - - return nullptr; - }; - - auto RS = - getResponsibilitySetWithLegacyFn(SymbolNameSet({Bar, Baz}), LegacyLookup); - - EXPECT_TRUE(!!RS) << "Expected getResponsibilitySetWithLegacyFn to succeed"; - EXPECT_EQ(RS->size(), 1U) << "Wrong number of symbols returned"; - EXPECT_EQ(RS->count(Bar), 1U) << "Incorrect responsibility set returned"; - EXPECT_FALSE(BarMaterialized) - << "lookupFlags should not have materialized bar"; - - bool OnResolvedRun = false; - bool OnReadyRun = false; - auto OnResolved = [&](Expected<SymbolMap> Result) { - OnResolvedRun = true; - EXPECT_TRUE(!!Result) << "lookuWithLegacy failed to resolve"; - - EXPECT_EQ(Result->size(), 2U) << "Wrong number of symbols resolved"; - EXPECT_EQ(Result->count(Foo), 1U) << "Result for foo missing"; - EXPECT_EQ(Result->count(Bar), 1U) << "Result for bar missing"; - EXPECT_EQ((*Result)[Foo].getAddress(), FooAddr) << "Wrong address for foo"; - EXPECT_EQ((*Result)[Foo].getFlags(), FooSym.getFlags()) - << "Wrong flags for foo"; - EXPECT_EQ((*Result)[Bar].getAddress(), BarAddr) << "Wrong address for bar"; - EXPECT_EQ((*Result)[Bar].getFlags(), BarSym.getFlags()) - << "Wrong flags for bar"; - }; - auto OnReady = [&](Error Err) { - EXPECT_FALSE(!!Err) << "Finalization unexpectedly failed"; - OnReadyRun = true; - }; - - AsynchronousSymbolQuery Q({Foo, Bar}, OnResolved, OnReady); - auto Unresolved = - lookupWithLegacyFn(ES, Q, SymbolNameSet({Foo, Bar, Baz}), LegacyLookup); - - EXPECT_TRUE(OnResolvedRun) << "OnResolved was not run"; - EXPECT_TRUE(OnReadyRun) << "OnReady was not run"; - EXPECT_EQ(Unresolved.size(), 1U) << "Expected one unresolved symbol"; - EXPECT_EQ(Unresolved.count(Baz), 1U) << "Expected baz to be unresolved"; -} - -} // namespace |
