forked from OSchip/llvm-project
[clang] add tests to ExprMutAnalyzer that reproduced a crash in ASTMatchers
Summary: This patch adds two unit-tests that are the result of reducing a crashing TU when running ExprMutAnalyzer over it. They are added only to ensure the regression that has been fixed with https://reviews.llvm.org/D56444 don't creep back. Reviewers: aaron.ballman, sammccall, rsmith, george.karpenkov Reviewed By: sammccall Subscribers: baloghadamsoftware, a.sidorin, Szelethus, donat.nagy, dkrupp, cfe-commits Differential Revision: https://reviews.llvm.org/D56917 llvm-svn: 351743
This commit is contained in:
parent
b68dd05c14
commit
67b7e23fa1
|
@ -1108,4 +1108,23 @@ TEST(ExprMutationAnalyzerTest, UniquePtr) {
|
|||
EXPECT_THAT(mutatedBy(Results, AST.get()), ElementsAre("x->mf()"));
|
||||
}
|
||||
|
||||
TEST(ExprMutationAnalyzerTest, ReproduceFailureMinimal) {
|
||||
const std::string Reproducer =
|
||||
"namespace std {"
|
||||
"template <class T> T forward(T & A) { return static_cast<T&&>(A); }"
|
||||
"template <class T> struct __bind {"
|
||||
" T f;"
|
||||
" template <class V> __bind(T v, V &&) : f(forward(v)) {}"
|
||||
"};"
|
||||
"}"
|
||||
"void f() {"
|
||||
" int x = 42;"
|
||||
" auto Lambda = [] {};"
|
||||
" std::__bind<decltype(Lambda)>(Lambda, x);"
|
||||
"}";
|
||||
auto AST11 = buildASTFromCodeWithArgs(Reproducer, {"-std=c++11"});
|
||||
auto Results11 =
|
||||
match(withEnclosingCompound(declRefTo("x")), AST11->getASTContext());
|
||||
EXPECT_FALSE(isMutated(Results11, AST11.get()));
|
||||
}
|
||||
} // namespace clang
|
||||
|
|
Loading…
Reference in New Issue