1 //===- unittest/AST/ASTTypeTraits.cpp - AST type traits unit tests ------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===--------------------------------------------------------------------===//
9 
10 
11 #include "clang/AST/ASTTypeTraits.h"
12 #include "MatchVerifier.h"
13 #include "gtest/gtest.h"
14 
15 using namespace clang::ast_matchers;
16 
17 namespace clang {
18 namespace ast_type_traits {
19 
TEST(ASTNodeKind,NoKind)20 TEST(ASTNodeKind, NoKind) {
21   EXPECT_FALSE(ASTNodeKind().isBaseOf(ASTNodeKind()));
22   EXPECT_FALSE(ASTNodeKind().isSame(ASTNodeKind()));
23 }
24 
DNT()25 template <typename T> static ASTNodeKind DNT() {
26   return ASTNodeKind::getFromNodeKind<T>();
27 }
28 
TEST(ASTNodeKind,IsNone)29 TEST(ASTNodeKind, IsNone) {
30   EXPECT_TRUE(ASTNodeKind().isNone());
31   EXPECT_FALSE(DNT<Decl>().isNone());
32   EXPECT_FALSE(DNT<VarDecl>().isNone());
33 }
34 
TEST(ASTNodeKind,Bases)35 TEST(ASTNodeKind, Bases) {
36   EXPECT_TRUE(DNT<Decl>().isBaseOf(DNT<VarDecl>()));
37   EXPECT_FALSE(DNT<Decl>().isSame(DNT<VarDecl>()));
38   EXPECT_FALSE(DNT<VarDecl>().isBaseOf(DNT<Decl>()));
39 
40   EXPECT_TRUE(DNT<Decl>().isSame(DNT<Decl>()));
41 }
42 
TEST(ASTNodeKind,BaseDistances)43 TEST(ASTNodeKind, BaseDistances) {
44   unsigned Distance = 1;
45   EXPECT_TRUE(DNT<Expr>().isBaseOf(DNT<Expr>(), &Distance));
46   EXPECT_EQ(0u, Distance);
47 
48   EXPECT_TRUE(DNT<Stmt>().isBaseOf(DNT<IfStmt>(), &Distance));
49   EXPECT_EQ(1u, Distance);
50 
51   Distance = 3;
52   EXPECT_TRUE(DNT<DeclaratorDecl>().isBaseOf(DNT<ParmVarDecl>(), &Distance));
53   EXPECT_EQ(2u, Distance);
54 }
55 
TEST(ASTNodeKind,SameBase)56 TEST(ASTNodeKind, SameBase) {
57   EXPECT_TRUE(DNT<Expr>().isBaseOf(DNT<CallExpr>()));
58   EXPECT_TRUE(DNT<Expr>().isBaseOf(DNT<BinaryOperator>()));
59   EXPECT_FALSE(DNT<CallExpr>().isBaseOf(DNT<BinaryOperator>()));
60   EXPECT_FALSE(DNT<BinaryOperator>().isBaseOf(DNT<CallExpr>()));
61 }
62 
TEST(ASTNodeKind,DiffBase)63 TEST(ASTNodeKind, DiffBase) {
64   EXPECT_FALSE(DNT<Expr>().isBaseOf(DNT<ArrayType>()));
65   EXPECT_FALSE(DNT<QualType>().isBaseOf(DNT<FunctionDecl>()));
66   EXPECT_FALSE(DNT<Type>().isSame(DNT<QualType>()));
67 }
68 
TEST(ASTNodeKind,MostDerivedType)69 TEST(ASTNodeKind, MostDerivedType) {
70   EXPECT_TRUE(DNT<BinaryOperator>().isSame(
71       ASTNodeKind::getMostDerivedType(DNT<Expr>(), DNT<BinaryOperator>())));
72   EXPECT_TRUE(DNT<BinaryOperator>().isSame(
73       ASTNodeKind::getMostDerivedType(DNT<BinaryOperator>(), DNT<Expr>())));
74   EXPECT_TRUE(DNT<VarDecl>().isSame(
75       ASTNodeKind::getMostDerivedType(DNT<VarDecl>(), DNT<VarDecl>())));
76 
77   // Not related. Returns nothing.
78   EXPECT_TRUE(
79       ASTNodeKind::getMostDerivedType(DNT<IfStmt>(), DNT<VarDecl>()).isNone());
80   EXPECT_TRUE(ASTNodeKind::getMostDerivedType(DNT<IfStmt>(),
81                                               DNT<BinaryOperator>()).isNone());
82 }
83 
TEST(ASTNodeKind,MostDerivedCommonAncestor)84 TEST(ASTNodeKind, MostDerivedCommonAncestor) {
85   EXPECT_TRUE(DNT<Expr>().isSame(ASTNodeKind::getMostDerivedCommonAncestor(
86       DNT<Expr>(), DNT<BinaryOperator>())));
87   EXPECT_TRUE(DNT<Expr>().isSame(ASTNodeKind::getMostDerivedCommonAncestor(
88       DNT<BinaryOperator>(), DNT<Expr>())));
89   EXPECT_TRUE(DNT<VarDecl>().isSame(ASTNodeKind::getMostDerivedCommonAncestor(
90       DNT<VarDecl>(), DNT<VarDecl>())));
91 
92   // A little related. Returns the ancestor.
93   EXPECT_TRUE(
94       DNT<NamedDecl>().isSame(ASTNodeKind::getMostDerivedCommonAncestor(
95           DNT<CXXMethodDecl>(), DNT<RecordDecl>())));
96 
97   // Not related. Returns nothing.
98   EXPECT_TRUE(ASTNodeKind::getMostDerivedCommonAncestor(
99                   DNT<IfStmt>(), DNT<VarDecl>()).isNone());
100 }
101 
102 struct Foo {};
103 
TEST(ASTNodeKind,UnknownKind)104 TEST(ASTNodeKind, UnknownKind) {
105   // We can construct one, but it is nowhere in the hierarchy.
106   EXPECT_FALSE(DNT<Foo>().isSame(DNT<Foo>()));
107 }
108 
TEST(ASTNodeKind,Name)109 TEST(ASTNodeKind, Name) {
110   EXPECT_EQ("Decl", DNT<Decl>().asStringRef());
111   EXPECT_EQ("CallExpr", DNT<CallExpr>().asStringRef());
112   EXPECT_EQ("ConstantArrayType", DNT<ConstantArrayType>().asStringRef());
113   EXPECT_EQ("<None>", ASTNodeKind().asStringRef());
114 }
115 
TEST(DynTypedNode,DeclSourceRange)116 TEST(DynTypedNode, DeclSourceRange) {
117   RangeVerifier<DynTypedNode> Verifier;
118   Verifier.expectRange(1, 1, 1, 11);
119   EXPECT_TRUE(Verifier.match("void f() {}", decl()));
120 }
121 
TEST(DynTypedNode,StmtSourceRange)122 TEST(DynTypedNode, StmtSourceRange) {
123   RangeVerifier<DynTypedNode> Verifier;
124   Verifier.expectRange(1, 10, 1, 11);
125   EXPECT_TRUE(Verifier.match("void f() {}", stmt()));
126 }
127 
TEST(DynTypedNode,TypeLocSourceRange)128 TEST(DynTypedNode, TypeLocSourceRange) {
129   RangeVerifier<DynTypedNode> Verifier;
130   Verifier.expectRange(1, 1, 1, 8);
131   EXPECT_TRUE(Verifier.match("void f() {}", typeLoc(loc(functionType()))));
132 }
133 
TEST(DynTypedNode,NNSLocSourceRange)134 TEST(DynTypedNode, NNSLocSourceRange) {
135   RangeVerifier<DynTypedNode> Verifier;
136   Verifier.expectRange(1, 33, 1, 34);
137   EXPECT_TRUE(Verifier.match("namespace N { typedef void T; } N::T f() {}",
138                              nestedNameSpecifierLoc()));
139 }
140 
TEST(DynTypedNode,DeclDump)141 TEST(DynTypedNode, DeclDump) {
142   DumpVerifier Verifier;
143   Verifier.expectSubstring("FunctionDecl");
144   EXPECT_TRUE(Verifier.match("void f() {}", functionDecl()));
145 }
146 
TEST(DynTypedNode,StmtDump)147 TEST(DynTypedNode, StmtDump) {
148   DumpVerifier Verifier;
149   Verifier.expectSubstring("CompoundStmt");
150   EXPECT_TRUE(Verifier.match("void f() {}", stmt()));
151 }
152 
TEST(DynTypedNode,DeclPrint)153 TEST(DynTypedNode, DeclPrint) {
154   PrintVerifier Verifier;
155   Verifier.expectString("void f() {\n}\n\n");
156   EXPECT_TRUE(Verifier.match("void f() {}", functionDecl()));
157 }
158 
TEST(DynTypedNode,StmtPrint)159 TEST(DynTypedNode, StmtPrint) {
160   PrintVerifier Verifier;
161   Verifier.expectString("{\n}\n");
162   EXPECT_TRUE(Verifier.match("void f() {}", stmt()));
163 }
164 
165 }  // namespace ast_type_traits
166 }  // namespace clang
167