summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/unittests/clang-query/QueryEngineTest.cpp
diff options
context:
space:
mode:
authorSamuel Benzaquen <sbenza@google.com>2014-04-23 14:04:52 +0000
committerSamuel Benzaquen <sbenza@google.com>2014-04-23 14:04:52 +0000
commit1f6066c9acced984fb808284f40c834a8740fb2b (patch)
tree9791b9784fc6376a872c3a048630e0ae4d965c6f /clang-tools-extra/unittests/clang-query/QueryEngineTest.cpp
parent5a7c3643437c262137bd3dac7f6a0f5b9e8501be (diff)
downloadbcm5719-llvm-1f6066c9acced984fb808284f40c834a8740fb2b.tar.gz
bcm5719-llvm-1f6066c9acced984fb808284f40c834a8740fb2b.zip
Add new 'let' command to bind arbitrary values into constants.
Summary: Add new 'let' command to bind arbitrary values into constants. These constants can then be used in the matcher expressions. Reviewers: pcc CC: cfe-commits Differential Revision: http://reviews.llvm.org/D3383 llvm-svn: 206984
Diffstat (limited to 'clang-tools-extra/unittests/clang-query/QueryEngineTest.cpp')
-rw-r--r--clang-tools-extra/unittests/clang-query/QueryEngineTest.cpp48
1 files changed, 38 insertions, 10 deletions
diff --git a/clang-tools-extra/unittests/clang-query/QueryEngineTest.cpp b/clang-tools-extra/unittests/clang-query/QueryEngineTest.cpp
index f79bedeb537..495d3d08258 100644
--- a/clang-tools-extra/unittests/clang-query/QueryEngineTest.cpp
+++ b/clang-tools-extra/unittests/clang-query/QueryEngineTest.cpp
@@ -8,6 +8,7 @@
//===----------------------------------------------------------------------===//
#include "Query.h"
+#include "QueryParser.h"
#include "QuerySession.h"
#include "clang/ASTMatchers/ASTMatchers.h"
#include "clang/ASTMatchers/Dynamic/VariantValue.h"
@@ -24,20 +25,22 @@ using namespace clang::ast_matchers::dynamic;
using namespace clang::query;
using namespace clang::tooling;
-TEST(Query, Basic) {
- std::unique_ptr<ASTUnit> FooAST(
- buildASTFromCode("void foo1(void) {}\nvoid foo2(void) {}", "foo.cc"));
- ASSERT_TRUE(FooAST.get());
- std::unique_ptr<ASTUnit> BarAST(
- buildASTFromCode("void bar1(void) {}\nvoid bar2(void) {}", "bar.cc"));
- ASSERT_TRUE(BarAST.get());
+class QueryEngineTest : public ::testing::Test {
+protected:
+ QueryEngineTest() {}
- ASTUnit *ASTs[] = { FooAST.get(), BarAST.get() };
+ std::unique_ptr<ASTUnit> FooAST{
+ buildASTFromCode("void foo1(void) {}\nvoid foo2(void) {}", "foo.cc")};
+ std::unique_ptr<ASTUnit> BarAST{
+ buildASTFromCode("void bar1(void) {}\nvoid bar2(void) {}", "bar.cc")};
+ ASTUnit *ASTs[2]{FooAST.get(), BarAST.get()};
+ QuerySession S{ASTs};
std::string Str;
- llvm::raw_string_ostream OS(Str);
- QuerySession S(ASTs);
+ llvm::raw_string_ostream OS{Str};
+};
+TEST_F(QueryEngineTest, Basic) {
DynTypedMatcher FnMatcher = functionDecl();
DynTypedMatcher FooMatcher = functionDecl(hasName("foo1"));
@@ -108,3 +111,28 @@ TEST(Query, Basic) {
EXPECT_EQ("Not a valid top-level matcher.\n", OS.str());
}
+
+TEST_F(QueryEngineTest, LetAndMatch) {
+ EXPECT_TRUE(QueryParser::parse("let x \"foo1\"", S)->run(OS, S));
+ EXPECT_EQ("", OS.str());
+ Str.clear();
+
+ EXPECT_TRUE(QueryParser::parse("let y hasName(x)", S)->run(OS, S));
+ EXPECT_EQ("", OS.str());
+ Str.clear();
+
+ EXPECT_TRUE(QueryParser::parse("match functionDecl(y)", S)->run(OS, S));
+ EXPECT_TRUE(OS.str().find("foo.cc:1:1: note: \"root\" binds here") !=
+ std::string::npos);
+ EXPECT_TRUE(OS.str().find("1 match.") != std::string::npos);
+ Str.clear();
+
+ EXPECT_TRUE(QueryParser::parse("unlet x", S)->run(OS, S));
+ EXPECT_EQ("", OS.str());
+ Str.clear();
+
+ EXPECT_FALSE(QueryParser::parse("let y hasName(x)", S)->run(OS, S));
+ EXPECT_EQ("1:2: Error parsing argument 1 for matcher hasName.\n"
+ "1:10: Value not found: x\n", OS.str());
+ Str.clear();
+}
OpenPOWER on IntegriCloud