summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/cppmodelmanager_test.cpp
diff options
context:
space:
mode:
authorErik Verbruggen <erik.verbruggen@digia.com>2012-12-20 15:53:12 +0100
committerErik Verbruggen <erik.verbruggen@digia.com>2013-01-24 11:36:22 +0100
commitfa7ab13f300b49122f3f951c8995ec88041f1ddb (patch)
tree2bf01c09c082c470f582f373d7a21092cd541d8a /src/plugins/cpptools/cppmodelmanager_test.cpp
parentfcf586974f7bb1b058d5651ba1143f131f1c8d4a (diff)
downloadqt-creator-fa7ab13f300b49122f3f951c8995ec88041f1ddb.tar.gz
C++: test for walking includes in frameworks.
Change-Id: Id31ce6b40d72351cfaefa5035469b87662526853 Reviewed-by: Nikolai Kosjar <nikolai.kosjar@digia.com> Reviewed-by: Erik Verbruggen <erik.verbruggen@digia.com>
Diffstat (limited to 'src/plugins/cpptools/cppmodelmanager_test.cpp')
-rw-r--r--src/plugins/cpptools/cppmodelmanager_test.cpp46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/plugins/cpptools/cppmodelmanager_test.cpp b/src/plugins/cpptools/cppmodelmanager_test.cpp
index 51cc82f5ed..bc786e8bdb 100644
--- a/src/plugins/cpptools/cppmodelmanager_test.cpp
+++ b/src/plugins/cpptools/cppmodelmanager_test.cpp
@@ -28,6 +28,7 @@
****************************************************************************/
#include "cpptoolsplugin.h"
+#include "CppDocument.h"
#include "cppmodelmanager.h"
#include "modelmanagertesthelper.h"
@@ -36,6 +37,7 @@
using namespace CppTools::Internal;
+typedef CPlusPlus::Document Document;
typedef CPlusPlus::CppModelManagerInterface::ProjectInfo ProjectInfo;
typedef CPlusPlus::CppModelManagerInterface::ProjectPart ProjectPart;
typedef ProjectExplorer::Project Project;
@@ -61,6 +63,11 @@ QString testFrameworksDir(bool cleaned = true)
{
return testDataDir(QLatin1String("frameworks"), cleaned);
}
+
+QString testSource(const QString &fileName)
+{
+ return testDataDir(QLatin1String("sources")) + fileName;
+}
} // anonymous namespace
void CppToolsPlugin::test_modelmanager_paths()
@@ -90,3 +97,42 @@ void CppToolsPlugin::test_modelmanager_paths()
QCOMPARE(frameworkPaths.size(), 1);
QVERIFY(frameworkPaths.contains(testFrameworksDir()));
}
+
+void CppToolsPlugin::test_modelmanager_framework_headers()
+{
+ ModelManagerTestHelper helper;
+ CppModelManager *mm = CppModelManager::instance();
+
+ Project *project = helper.createProject(QLatin1String("test_modelmanager_framework_headers"));
+ ProjectInfo pi = mm->projectInfo(project);
+ QCOMPARE(pi.project().data(), project);
+
+ ProjectPart::Ptr part(new ProjectPart);
+ pi.appendProjectPart(part);
+ part->language = ProjectPart::CXX;
+ part->qtVersion = ProjectPart::Qt5;
+ part->defines = QByteArray("#define OH_BEHAVE -1\n");
+ part->includePaths << testIncludeDir();
+ part->frameworkPaths << testFrameworksDir();
+ part->sourceFiles << testSource(QLatin1String("test_modelmanager_framework_headers.cpp"));
+
+ mm->updateProjectInfo(pi);
+ mm->updateSourceFiles(part->sourceFiles).waitForFinished();
+ QCoreApplication::processEvents();
+
+ QVERIFY(mm->snapshot().contains(part->sourceFiles.first()));
+ Document::Ptr doc = mm->snapshot().document(part->sourceFiles.first());
+ QVERIFY(!doc.isNull());
+ CPlusPlus::Namespace *ns = doc->globalNamespace();
+ QVERIFY(ns);
+ QVERIFY(ns->memberCount() > 0);
+ for (unsigned i = 0, ei = ns->memberCount(); i < ei; ++i) {
+ CPlusPlus::Symbol *s = ns->memberAt(i);
+ QVERIFY(s);
+ QVERIFY(s->name());
+ const CPlusPlus::Identifier *id = s->name()->asNameId();
+ QVERIFY(id);
+ QByteArray chars = id->chars();
+ QVERIFY(chars.startsWith("success"));
+ }
+}