summaryrefslogtreecommitdiffstats
path: root/tests/auto/qhelpgenerator/tst_qhelpgenerator.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/auto/qhelpgenerator/tst_qhelpgenerator.cpp')
-rw-r--r--tests/auto/qhelpgenerator/tst_qhelpgenerator.cpp218
1 files changed, 218 insertions, 0 deletions
diff --git a/tests/auto/qhelpgenerator/tst_qhelpgenerator.cpp b/tests/auto/qhelpgenerator/tst_qhelpgenerator.cpp
new file mode 100644
index 0000000..207fdbe
--- /dev/null
+++ b/tests/auto/qhelpgenerator/tst_qhelpgenerator.cpp
@@ -0,0 +1,218 @@
+/****************************************************************************
+**
+** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
+** Contact: Qt Software Information (qt-info@nokia.com)
+**
+** This file is part of the test suite of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** No Commercial Usage
+** This file contains pre-release code and may not be distributed.
+** You may use this file in accordance with the terms and conditions
+** contained in the either Technology Preview License Agreement or the
+** Beta Release License Agreement.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Nokia gives you certain
+** additional rights. These rights are described in the Nokia Qt LGPL
+** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
+** package.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU
+** General Public License version 3.0 as published by the Free Software
+** Foundation and appearing in the file LICENSE.GPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU General Public License version 3.0 requirements will be
+** met: http://www.gnu.org/copyleft/gpl.html.
+**
+** If you are unsure which license is appropriate for your use, please
+** contact the sales department at qt-sales@nokia.com.
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+#include <QtTest/QtTest>
+
+#ifndef QT_NO_BUILD_TOOLS
+
+#include <QtCore/QFileInfo>
+#include <QtSql/QSqlDatabase>
+#include <QtSql/QSqlQuery>
+
+#include <QtHelp/private/qhelpgenerator_p.h>
+#include <QtHelp/private/qhelpprojectdata_p.h>
+
+class tst_QHelpGenerator : public QObject
+{
+ Q_OBJECT
+
+private slots:
+ void initTestCase();
+ void generateHelp();
+
+private:
+ void checkNamespace();
+ void checkFilters();
+ void checkIndices();
+ void checkFiles();
+ void checkMetaData();
+
+ QString m_outputFile;
+ QSqlQuery *m_query;
+};
+
+void tst_QHelpGenerator::initTestCase()
+{
+ QString path = QLatin1String(SRCDIR);
+ m_outputFile = path + QLatin1String("/data/test.qch");
+ if (QFile::exists(m_outputFile)) {
+ QDir d;
+ if (!d.remove(m_outputFile))
+ QFAIL("Cannot remove old output file!");
+ }
+}
+
+void tst_QHelpGenerator::generateHelp()
+{
+ // defined in profile
+ QString path = QLatin1String(SRCDIR);
+
+ QString inputFile(path + "/data/test.qhp");
+ QHelpProjectData data;
+ if (!data.readData(inputFile))
+ QFAIL("Cannot read qthp file!");
+
+ QHelpGenerator generator;
+ QCOMPARE(generator.generate(&data, m_outputFile), true);
+
+ {
+ QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE", "testdb");
+ db.setDatabaseName(m_outputFile);
+ if (!db.open()) {
+ QSqlDatabase::removeDatabase("testdb");
+ QFAIL("Created database seems to be corrupt!");
+ }
+ m_query = new QSqlQuery(db);
+ checkNamespace();
+ checkFilters();
+ checkIndices();
+ checkFiles();
+ checkMetaData();
+
+ m_query->clear();
+ delete m_query;
+ }
+ QSqlDatabase::removeDatabase("testdb");
+
+ // check if db is still in use...
+ initTestCase();
+}
+
+void tst_QHelpGenerator::checkNamespace()
+{
+ m_query->exec("SELECT Id, Name FROM NamespaceTable");
+ if (m_query->next()
+ && m_query->value(1).toString() == QLatin1String("trolltech.com.1_0_0.test"))
+ return;
+ QFAIL("Namespace Error!");
+}
+
+void tst_QHelpGenerator::checkFilters()
+{
+ m_query->exec("SELECT COUNT(Id) FROM FilterAttributeTable");
+ if (!m_query->next() || m_query->value(0).toInt() != 3)
+ QFAIL("FilterAttribute Error!");
+
+ m_query->exec("SELECT a.Name FROM FilterAttributeTable a, FilterTable b, "
+ "FilterNameTable c WHERE c.Id=b.NameId AND b.FilterAttributeID=a.Id "
+ "AND c.Name=\'Custom Filter 2\'");
+ QStringList lst;
+ while (m_query->next())
+ lst.append(m_query->value(0).toString());
+ if (!lst.contains("test") || !lst.contains("filter2"))
+ QFAIL("FilterAttribute Error!");
+}
+
+void tst_QHelpGenerator::checkIndices()
+{
+ m_query->exec("SELECT a.Name, b.Anchor FROM FileNameTable a, "
+ "IndexTable b, IndexFilterTable c, FilterAttributeTable d "
+ "WHERE a.FileID=b.FileId AND b.Id=c.IndexId "
+ "AND c.FilterAttributeId=d.Id AND d.Name=\'filter1\' AND b.Name=\'foo\'");
+ if (!m_query->next() || m_query->value(0).toString() != QLatin1String("test.html")
+ || m_query->value(1).toString() != QLatin1String("foo"))
+ QFAIL("Index Error!");
+
+ /*
+ m_query->exec("SELECT COUNT(DISTINCT Id) FROM IndexItemTable");
+ if (!m_query->next() || m_query->value(0).toInt() != 7)
+ QFAIL("Index Error!");
+ */
+
+ m_query->exec("SELECT COUNT(a.Id) FROM IndexTable a, "
+ "IndexFilterTable b, FilterAttributeTable c WHERE a.Id=b.IndexId "
+ "AND b.FilterAttributeId=c.Id AND c.Name=\'filter2\'");
+ if (!m_query->next() || m_query->value(0).toInt() != 3)
+ QFAIL("Index Error!");
+}
+
+void tst_QHelpGenerator::checkFiles()
+{
+ m_query->exec("SELECT COUNT(a.FileId) FROM FileNameTable a, FolderTable b "
+ "WHERE a.FolderId=b.Id AND b.Name=\'testFolder\'");
+ if (!m_query->next() || m_query->value(0).toInt() != 6)
+ QFAIL("File Error!");
+
+ QStringList lst;
+ lst << "classic.css" << "test.html" << "people.html" << "sub/about.html";
+ m_query->exec("SELECT a.Name FROM FileNameTable a, FileFilterTable b, "
+ "FilterAttributeTable c WHERE c.Id=b.FilterAttributeId "
+ "AND b.FileId=a.FileID AND c.Name=\'filter1\'");
+ while (m_query->next())
+ lst.removeAll(m_query->value(0).toString());
+ QCOMPARE(lst.count(), 0);
+
+ QMap<int, QStringList> fileAtts;
+ m_query->exec("SELECT a.Id, b.Name FROM FileAttributeSetTable a, "
+ "FilterAttributeTable b WHERE a.FilterAttributeId=b.Id");
+ while (m_query->next()) {
+ int id = m_query->value(0).toInt();
+ if (!fileAtts.contains(id))
+ fileAtts.insert(id, QStringList());
+ fileAtts[id].append(m_query->value(1).toString());
+ }
+ QCOMPARE(fileAtts.count(), 2);
+ QCOMPARE((bool)fileAtts.value(1).contains("test"), true);
+ QCOMPARE((bool)fileAtts.value(1).contains("filter1"), true);
+ QCOMPARE((bool)fileAtts.value(1).contains("filter2"), false);
+ QCOMPARE((bool)fileAtts.value(2).contains("test"), true);
+ QCOMPARE((bool)fileAtts.value(2).contains("filter2"), true);
+}
+
+void tst_QHelpGenerator::checkMetaData()
+{
+ m_query->exec("SELECT COUNT(Value) FROM MetaDataTable");
+ if (!m_query->next())
+ QFAIL("Meta Data Error");
+ QCOMPARE(m_query->value(0).toInt(), 4);
+
+ m_query->exec("SELECT Value FROM MetaDataTable WHERE Name=\'author\'");
+ if (!m_query->next())
+ QFAIL("Meta Data Error");
+ QCOMPARE(m_query->value(0).toString(), QString("Nokia Corporation and/or its subsidiary(-ies)"));
+}
+
+QTEST_MAIN(tst_QHelpGenerator)
+#include "tst_qhelpgenerator.moc"
+
+#else // QT_NO_BUILD_TOOLS
+QTEST_NOOP_MAIN
+#endif
+