/**************************************************************************** ** ** Copyright (C) 2015 The Qt Company Ltd. ** Copyright (C) 2016 Ivailo Monev ** ** This file is part of the test suite of the Katie Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** ** GNU Lesser General Public License Usage ** 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. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include #include #include #include #include #include //TESTED_FILES= class tst_QImageReader : public QObject { Q_OBJECT public: tst_QImageReader(); virtual ~tst_QImageReader(); private slots: void readImage_data(); void readImage(); void setScaledSize_data(); void setScaledSize(); void setClipRect_data(); void setClipRect(); void setScaledClipRect_data(); void setScaledClipRect(); private: QList< QPair > images; // filename, format }; tst_QImageReader::tst_QImageReader() { foreach (const QByteArray &format, QImageReader::supportedImageFormats()) { if (format == "svgz") { // TODO: svgz image continue; } images << QPair(QLatin1String("bench.") + format, format); } } tst_QImageReader::~tst_QImageReader() { } void tst_QImageReader::readImage_data() { QTest::addColumn("fileName"); QTest::addColumn("format"); for (int i = 0; i < images.size(); ++i) { const QString file = images[i].first; const QByteArray format = images[i].second; QTest::newRow(qPrintable(file)) << file << format; } } void tst_QImageReader::readImage() { QFETCH(QString, fileName); QFETCH(QByteArray, format); QBENCHMARK { QImageReader io(QLatin1String(SRCDIR "/images/") + fileName, format); QImage image = io.read(); QVERIFY(!image.isNull()); } } void tst_QImageReader::setScaledSize_data() { QTest::addColumn("fileName"); QTest::addColumn("format"); QTest::addColumn("newSize"); for (int i = 0; i < images.size(); ++i) { const QString file = images[i].first; const QByteArray format = images[i].second; QTest::newRow(qPrintable(file)) << file << format << QSize(200, 200); } } void tst_QImageReader::setScaledSize() { QFETCH(QString, fileName); QFETCH(QSize, newSize); QFETCH(QByteArray, format); QBENCHMARK { QImageReader reader(QLatin1String(SRCDIR "/images/") + fileName, format); reader.setScaledSize(newSize); QImage image = reader.read(); QCOMPARE(image.size(), newSize); } } void tst_QImageReader::setClipRect_data() { QTest::addColumn("fileName"); QTest::addColumn("format"); QTest::addColumn("newRect"); for (int i = 0; i < images.size(); ++i) { const QString file = images[i].first; const QByteArray format = images[i].second; QTest::newRow(qPrintable(file)) << file << format << QRect(0, 0, 50, 50); } } void tst_QImageReader::setClipRect() { QFETCH(QString, fileName); QFETCH(QRect, newRect); QFETCH(QByteArray, format); QBENCHMARK { QImageReader reader(QLatin1String(SRCDIR "/images/") + fileName, format); reader.setClipRect(newRect); QImage image = reader.read(); QCOMPARE(image.rect(), newRect); } } void tst_QImageReader::setScaledClipRect_data() { setClipRect_data(); } void tst_QImageReader::setScaledClipRect() { QFETCH(QString, fileName); QFETCH(QRect, newRect); QFETCH(QByteArray, format); QBENCHMARK { QImageReader reader(QLatin1String(SRCDIR "/images/") + fileName, format); reader.setScaledSize(QSize(300, 300)); reader.setScaledClipRect(newRect); QImage image = reader.read(); QCOMPARE(image.rect(), newRect); } } QTEST_MAIN(tst_QImageReader) #include "moc_tst_qimagereader.cpp"