diff options
author | Dimitry Andric <dim@FreeBSD.org> | 2017-04-16 16:02:28 +0000 |
---|---|---|
committer | Dimitry Andric <dim@FreeBSD.org> | 2017-04-16 16:02:28 +0000 |
commit | 7442d6faa2719e4e7d33a7021c406c5a4facd74d (patch) | |
tree | c72b9241553fc9966179aba84f90f17bfa9235c3 /unittests/Analysis/CFGTest.cpp | |
parent | b52119637f743680a99710ce5fdb6646da2772af (diff) |
Diffstat (limited to 'unittests/Analysis/CFGTest.cpp')
-rw-r--r-- | unittests/Analysis/CFGTest.cpp | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/unittests/Analysis/CFGTest.cpp b/unittests/Analysis/CFGTest.cpp index e691110050a22..768705f46f29f 100644 --- a/unittests/Analysis/CFGTest.cpp +++ b/unittests/Analysis/CFGTest.cpp @@ -35,7 +35,9 @@ public: if (!Body) return; TheBuildResult = SawFunctionBody; - if (CFG::buildCFG(nullptr, Body, Result.Context, CFG::BuildOptions())) + CFG::BuildOptions Options; + Options.AddImplicitDtors = true; + if (CFG::buildCFG(nullptr, Body, Result.Context, Options)) TheBuildResult = BuiltCFG; } }; @@ -75,6 +77,16 @@ TEST(CFG, DeleteExpressionOnDependentType) { EXPECT_EQ(BuiltCFG, BuildCFG(Code)); } +// Constructing a CFG on a function template with a variable of incomplete type +// should not crash. +TEST(CFG, VariableOfIncompleteType) { + const char *Code = "template<class T> void f() {\n" + " class Undefined;\n" + " Undefined u;\n" + "}\n"; + EXPECT_EQ(BuiltCFG, BuildCFG(Code)); +} + } // namespace } // namespace analysis } // namespace clang |