[llvm] r236865 - Prevent further errors of omission when adding backend names.
Douglas Katzman
dougk at google.com
Fri May 8 08:34:13 PDT 2015
Author: dougk
Date: Fri May 8 10:34:12 2015
New Revision: 236865
URL: http://llvm.org/viewvc/llvm-project?rev=236865&view=rev
Log:
Prevent further errors of omission when adding backend names.
Differential Revision: http://reviews.llvm.org/D9441
Added:
llvm/trunk/unittests/Support/TargetRegistry.cpp
Modified:
llvm/trunk/unittests/Support/CMakeLists.txt
Modified: llvm/trunk/unittests/Support/CMakeLists.txt
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/unittests/Support/CMakeLists.txt?rev=236865&r1=236864&r2=236865&view=diff
==============================================================================
--- llvm/trunk/unittests/Support/CMakeLists.txt (original)
+++ llvm/trunk/unittests/Support/CMakeLists.txt Fri May 8 10:34:12 2015
@@ -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
Added: llvm/trunk/unittests/Support/TargetRegistry.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/unittests/Support/TargetRegistry.cpp?rev=236865&view=auto
==============================================================================
--- llvm/trunk/unittests/Support/TargetRegistry.cpp (added)
+++ llvm/trunk/unittests/Support/TargetRegistry.cpp Fri May 8 10:34:12 2015
@@ -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
More information about the llvm-commits
mailing list