From d7e20e7be8d88a5ef134c9e5b37fec847f47c8ab Mon Sep 17 00:00:00 2001 From: Douglas Katzman Date: Fri, 8 May 2015 15:34:12 +0000 Subject: [PATCH] Prevent further errors of omission when adding backend names. Differential Revision: http://reviews.llvm.org/D9441 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@236865 91177308-0d34-0410-b5e6-96231b3b80d8 --- unittests/Support/CMakeLists.txt | 2 ++ unittests/Support/TargetRegistry.cpp | 43 ++++++++++++++++++++++++++++++++++++ 2 files changed, 45 insertions(+) create mode 100644 unittests/Support/TargetRegistry.cpp diff --git a/unittests/Support/CMakeLists.txt b/unittests/Support/CMakeLists.txt index 3c8a090c2ba..564d189d49c 100644 --- a/unittests/Support/CMakeLists.txt +++ b/unittests/Support/CMakeLists.txt @@ -1,4 +1,5 @@ set(LLVM_LINK_COMPONENTS + ${LLVM_TARGETS_TO_BUILD} Support ) @@ -37,6 +38,7 @@ add_llvm_unittest(SupportTests StreamingMemoryObject.cpp StringPool.cpp SwapByteOrderTest.cpp + TargetRegistry.cpp ThreadLocalTest.cpp TimeValueTest.cpp UnicodeTest.cpp diff --git a/unittests/Support/TargetRegistry.cpp b/unittests/Support/TargetRegistry.cpp new file mode 100644 index 00000000000..dd5ef431ae0 --- /dev/null +++ b/unittests/Support/TargetRegistry.cpp @@ -0,0 +1,43 @@ +//===- unittests/Support/TargetRegistry.cpp - -----------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#include "llvm/Support/TargetRegistry.h" +#include "llvm/Support/TargetSelect.h" +#include "gtest/gtest.h" + +using namespace llvm; + +namespace { + +TEST(TargetRegistry, TargetHasArchType) { + // Presence of at least one target will be asserted when done with the loop, + // else this would pass by accident if InitializeAllTargetInfos were omitted. + int Count = 0; + + llvm::InitializeAllTargetInfos(); + + llvm::TargetRegistry RegistryRoot; + for (const auto &Target : RegistryRoot) { + StringRef Name = Target.getName(); + // There is really no way (at present) to ask a Target whether it targets + // a specific architecture, because the logic for that is buried in a + // predicate. + // We can't ask the predicate "Are you a function that always returns + // false?" + // So given that the cpp backend truly has no target arch, it is skipped. + if (Name != "cpp") { + Triple::ArchType Arch = Triple::getArchTypeForLLVMName(Name); + EXPECT_NE(Arch, Triple::UnknownArch); + ++Count; + } + } + ASSERT_NE(Count, 0); +} + +} // end namespace -- 2.11.0