diff options
Diffstat (limited to 'src/plugins/cpptools/cppcompletion_test.cpp')
-rw-r--r-- | src/plugins/cpptools/cppcompletion_test.cpp | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/plugins/cpptools/cppcompletion_test.cpp b/src/plugins/cpptools/cppcompletion_test.cpp index 67af9b9497..11e380092b 100644 --- a/src/plugins/cpptools/cppcompletion_test.cpp +++ b/src/plugins/cpptools/cppcompletion_test.cpp @@ -1798,3 +1798,37 @@ void CppToolsPlugin::test_completion_namespace_alias_with_many_namespace_declara QVERIFY(completions.contains(QLatin1String("Foo1"))); QVERIFY(completions.contains(QLatin1String("Foo2"))); } + +void CppToolsPlugin::test_completion_crash_cloning_template_class_QTCREATORBUG9329() +{ + TestData data; + data.srcText = + "struct A {};\n" + "template <typename T>\n" + "struct Templ {};\n" + "struct B : A, Templ<A>\n" + "{\n" + " int f()\n" + " {\n" + " @\n" + " // padding so we get the scope right\n" + " }\n" + "};\n" + ; + setup(&data); + + Utils::ChangeSet change; + QString txt = QLatin1String("this->"); + change.insert(data.pos, txt); + QTextCursor cursor(data.doc); + change.apply(&cursor); + data.pos += txt.length(); + + QStringList completions = getCompletions(data); + + QCOMPARE(completions.size(), 4); + QVERIFY(completions.contains(QLatin1String("A"))); + QVERIFY(completions.contains(QLatin1String("B"))); + QVERIFY(completions.contains(QLatin1String("Templ"))); + QVERIFY(completions.contains(QLatin1String("f"))); +} |