summaryrefslogtreecommitdiffstats
path: root/llvm/unittests/MC/TargetRegistry.cpp
diff options
context:
space:
mode:
authorReid Kleckner <rnk@google.com>2016-02-03 21:41:24 +0000
committerReid Kleckner <rnk@google.com>2016-02-03 21:41:24 +0000
commit17495274fd746ae61e6688cc47b4cf0e8f735506 (patch)
treec2de7caa1d4c30e8cb61b34c2b92b9914df8473f /llvm/unittests/MC/TargetRegistry.cpp
parentc2e23116277bcca1e347ff2e0cbd43c09f0cda6b (diff)
downloadbcm5719-llvm-17495274fd746ae61e6688cc47b4cf0e8f735506.tar.gz
bcm5719-llvm-17495274fd746ae61e6688cc47b4cf0e8f735506.zip
[unittests] Move TargetRegistry test from Support to MC
This removes the dependency from SupportTests to all of the LLVM backends, and makes it link faster. llvm-svn: 259705
Diffstat (limited to 'llvm/unittests/MC/TargetRegistry.cpp')
-rw-r--r--llvm/unittests/MC/TargetRegistry.cpp46
1 files changed, 46 insertions, 0 deletions
diff --git a/llvm/unittests/MC/TargetRegistry.cpp b/llvm/unittests/MC/TargetRegistry.cpp
new file mode 100644
index 00000000000..eb46b22f06c
--- /dev/null
+++ b/llvm/unittests/MC/TargetRegistry.cpp
@@ -0,0 +1,46 @@
+//===- unittests/MC/TargetRegistry.cpp ------------------------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+// The target registry code lives in Support, but it relies on linking in all
+// LLVM targets. We keep this test with the MC tests, which already do that, to
+// keep the SupportTests target small.
+
+#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();
+
+ for (const Target &T : TargetRegistry::targets()) {
+ StringRef Name = T.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
OpenPOWER on IntegriCloud