//=======- CallGraphTest.cpp - Unit tests for the CG analysis -------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "llvm/Analysis/CallGraph.h" #include "llvm/IR/LLVMContext.h" #include "llvm/IR/Module.h" #include "gtest/gtest.h" using namespace llvm; namespace { template void canSpecializeGraphTraitsIterators(Ty *G) { typedef typename GraphTraits::NodeRef NodeRef; auto I = GraphTraits::nodes_begin(G); auto E = GraphTraits::nodes_end(G); auto X = ++I; // Should be able to iterate over all nodes of the graph. static_assert(std::is_same::value, "Node type does not match"); static_assert(std::is_same::value, "Node type does not match"); static_assert(std::is_same::value, "Node type does not match"); NodeRef N = GraphTraits::getEntryNode(G); auto S = GraphTraits::child_begin(N); auto F = GraphTraits::child_end(N); // Should be able to iterate over immediate successors of a node. static_assert(std::is_same::value, "Node type does not match"); static_assert(std::is_same::value, "Node type does not match"); } TEST(CallGraphTest, GraphTraitsSpecialization) { LLVMContext Context; Module M("", Context); CallGraph CG(M); canSpecializeGraphTraitsIterators(&CG); } TEST(CallGraphTest, GraphTraitsConstSpecialization) { LLVMContext Context; Module M("", Context); CallGraph CG(M); canSpecializeGraphTraitsIterators(const_cast(&CG)); } }