diff options
author | Peter Collingbourne <peter@pcc.me.uk> | 2014-02-01 01:42:46 +0000 |
---|---|---|
committer | Peter Collingbourne <peter@pcc.me.uk> | 2014-02-01 01:42:46 +0000 |
commit | d9a0f254bcd7e550bd504358fcda7a8e5b9906b3 (patch) | |
tree | f5ade30942fa795900b328c42bcaa679530417fe /clang-tools-extra/unittests/clang-query/QueryParserTest.cpp | |
parent | c31176da0265ee3b47c76e3a6af8273d5dd26561 (diff) | |
download | bcm5719-llvm-d9a0f254bcd7e550bd504358fcda7a8e5b9906b3.tar.gz bcm5719-llvm-d9a0f254bcd7e550bd504358fcda7a8e5b9906b3.zip |
Add completion to the query parser, and hook it up to clang-query.
Differential Revision: http://llvm-reviews.chandlerc.com/D2263
llvm-svn: 200604
Diffstat (limited to 'clang-tools-extra/unittests/clang-query/QueryParserTest.cpp')
-rw-r--r-- | clang-tools-extra/unittests/clang-query/QueryParserTest.cpp | 57 |
1 files changed, 41 insertions, 16 deletions
diff --git a/clang-tools-extra/unittests/clang-query/QueryParserTest.cpp b/clang-tools-extra/unittests/clang-query/QueryParserTest.cpp index 06737bc6976..e05eb8a892b 100644 --- a/clang-tools-extra/unittests/clang-query/QueryParserTest.cpp +++ b/clang-tools-extra/unittests/clang-query/QueryParserTest.cpp @@ -11,77 +11,102 @@ #include "Query.h" #include "QuerySession.h" #include "gtest/gtest.h" +#include "llvm/LineEditor/LineEditor.h" using namespace clang; using namespace clang::query; TEST(QueryParser, NoOp) { - QueryRef Q = ParseQuery(""); + QueryRef Q = QueryParser::parse(""); EXPECT_TRUE(isa<NoOpQuery>(Q)); - Q = ParseQuery("\n"); + Q = QueryParser::parse("\n"); EXPECT_TRUE(isa<NoOpQuery>(Q)); } TEST(QueryParser, Invalid) { - QueryRef Q = ParseQuery("foo"); + QueryRef Q = QueryParser::parse("foo"); ASSERT_TRUE(isa<InvalidQuery>(Q)); EXPECT_EQ("unknown command: foo", cast<InvalidQuery>(Q)->ErrStr); } TEST(QueryParser, Help) { - QueryRef Q = ParseQuery("help"); + QueryRef Q = QueryParser::parse("help"); ASSERT_TRUE(isa<HelpQuery>(Q)); - Q = ParseQuery("help me"); + Q = QueryParser::parse("help me"); ASSERT_TRUE(isa<InvalidQuery>(Q)); EXPECT_EQ("unexpected extra input: ' me'", cast<InvalidQuery>(Q)->ErrStr); } TEST(QueryParser, Set) { - QueryRef Q = ParseQuery("set"); + QueryRef Q = QueryParser::parse("set"); ASSERT_TRUE(isa<InvalidQuery>(Q)); EXPECT_EQ("expected variable name", cast<InvalidQuery>(Q)->ErrStr); - Q = ParseQuery("set foo bar"); + Q = QueryParser::parse("set foo bar"); ASSERT_TRUE(isa<InvalidQuery>(Q)); EXPECT_EQ("unknown variable: 'foo'", cast<InvalidQuery>(Q)->ErrStr); - Q = ParseQuery("set output"); + Q = QueryParser::parse("set output"); ASSERT_TRUE(isa<InvalidQuery>(Q)); - EXPECT_EQ("expected variable value", cast<InvalidQuery>(Q)->ErrStr); + EXPECT_EQ("expected 'diag', 'print' or 'dump', got ''", + cast<InvalidQuery>(Q)->ErrStr); - Q = ParseQuery("set bind-root true foo"); + Q = QueryParser::parse("set bind-root true foo"); ASSERT_TRUE(isa<InvalidQuery>(Q)); EXPECT_EQ("unexpected extra input: ' foo'", cast<InvalidQuery>(Q)->ErrStr); - Q = ParseQuery("set output foo"); + Q = QueryParser::parse("set output foo"); ASSERT_TRUE(isa<InvalidQuery>(Q)); EXPECT_EQ("expected 'diag', 'print' or 'dump', got 'foo'", cast<InvalidQuery>(Q)->ErrStr); - Q = ParseQuery("set output dump"); + Q = QueryParser::parse("set output dump"); ASSERT_TRUE(isa<SetQuery<OutputKind> >(Q)); EXPECT_EQ(&QuerySession::OutKind, cast<SetQuery<OutputKind> >(Q)->Var); EXPECT_EQ(OK_Dump, cast<SetQuery<OutputKind> >(Q)->Value); - Q = ParseQuery("set bind-root foo"); + Q = QueryParser::parse("set bind-root foo"); ASSERT_TRUE(isa<InvalidQuery>(Q)); EXPECT_EQ("expected 'true' or 'false', got 'foo'", cast<InvalidQuery>(Q)->ErrStr); - Q = ParseQuery("set bind-root true"); + Q = QueryParser::parse("set bind-root true"); ASSERT_TRUE(isa<SetQuery<bool> >(Q)); EXPECT_EQ(&QuerySession::BindRoot, cast<SetQuery<bool> >(Q)->Var); EXPECT_EQ(true, cast<SetQuery<bool> >(Q)->Value); } TEST(QueryParser, Match) { - QueryRef Q = ParseQuery("match decl()"); + QueryRef Q = QueryParser::parse("match decl()"); ASSERT_TRUE(isa<MatchQuery>(Q)); EXPECT_TRUE(cast<MatchQuery>(Q)->Matcher.canConvertTo<Decl>()); - Q = ParseQuery("m stmt()"); + Q = QueryParser::parse("m stmt()"); ASSERT_TRUE(isa<MatchQuery>(Q)); EXPECT_TRUE(cast<MatchQuery>(Q)->Matcher.canConvertTo<Stmt>()); } + +TEST(QueryParser, Complete) { + std::vector<llvm::LineEditor::Completion> Comps = + QueryParser::complete("", 0); + ASSERT_EQ(3u, Comps.size()); + EXPECT_EQ("help ", Comps[0].TypedText); + EXPECT_EQ("help", Comps[0].DisplayText); + EXPECT_EQ("match ", Comps[1].TypedText); + EXPECT_EQ("match", Comps[1].DisplayText); + EXPECT_EQ("set ", Comps[2].TypedText); + EXPECT_EQ("set", Comps[2].DisplayText); + + Comps = QueryParser::complete("set o", 5); + ASSERT_EQ(1u, Comps.size()); + EXPECT_EQ("utput ", Comps[0].TypedText); + EXPECT_EQ("output", Comps[0].DisplayText); + + Comps = QueryParser::complete("match while", 11); + ASSERT_EQ(1u, Comps.size()); + EXPECT_EQ("Stmt(", Comps[0].TypedText); + EXPECT_EQ("Matcher<Stmt> whileStmt(Matcher<WhileStmt>...)", + Comps[0].DisplayText); +} |