/**************************************************************************** ** ** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies). ** Contact: http://www.qt-project.org/legal ** ** This file is part of the test suite of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL21$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/contact-us. ** ** 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 or version 3 as published by the Free ** Software Foundation and appearing in the file LICENSE.LGPLv21 and ** LICENSE.LGPLv3 included in the packaging of this file. Please review the ** following information to ensure the GNU Lesser General Public License ** requirements will be met: https://www.gnu.org/licenses/lgpl.html and ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Digia gives you certain additional ** rights. These rights are described in the Digia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include #include #include #include #include "../qxmlquery/TestFundament.h" /*! \class tst_CheckXMLFiles \internal \since 4.4 \brief Checks whether the XML files found in $QTDIR are well-formed. */ class tst_CheckXMLFiles : public QObject , private TestFundament { Q_OBJECT private Q_SLOTS: void checkXMLFiles() const; void checkXMLFiles_data() const; }; void tst_CheckXMLFiles::checkXMLFiles() const { QFETCH(QString, file); QXmlQuery query; query.setQuery(QLatin1String("doc-available('") + inputFileAsURI(file).toString() + QLatin1String("')")); QVERIFY(query.isValid()); /* We don't care about the result, we only want to ensure the files can be parsed. */ QByteArray dummy; QBuffer buffer(&dummy); QVERIFY(buffer.open(QIODevice::WriteOnly)); QXmlSerializer serializer(query, &buffer); /* This is the important one. */ QVERIFY(query.evaluateTo(&serializer)); } void tst_CheckXMLFiles::checkXMLFiles_data() const { QTest::addColumn("file"); QStringList patterns; /* List possible XML files in Qt. */ patterns.append(QLatin1String("*.xml")); patterns.append(QLatin1String("*.gccxml")); patterns.append(QLatin1String("*.svg")); patterns.append(QLatin1String("*.ui")); patterns.append(QLatin1String("*.qrc")); patterns.append(QLatin1String("*.ts")); /* We don't do HTML files currently because so many of them in 3rd party are broken. */ patterns.append(QLatin1String("*.xhtml")); #ifndef Q_OS_WINCE QString path = QLatin1String(SOURCETREE); #else QString path = QFINDTESTDATA("xmlfiles"); #endif QDirIterator it(path, patterns, QDir::AllEntries, QDirIterator::Subdirectories); while(it.hasNext()) { it.next(); QTest::newRow(it.filePath().toUtf8().constData()) << it.filePath(); } } QTEST_MAIN(tst_CheckXMLFiles) #include "tst_checkxmlfiles.moc" // vim: et:ts=4:sw=4:sts=4