summaryrefslogtreecommitdiffstats
path: root/tests/auto/corelib/tools/qsizef
diff options
context:
space:
mode:
authorHolger Ihrig <holger.ihrig@nokia.com>2011-08-26 15:03:33 +0200
committerHolger Ihrig <holger.ihrig@nokia.com>2011-09-01 13:07:23 +0200
commit5c27f0a2fb772279fb3e4d60f7c879f5cecb3352 (patch)
tree12ef0e9acc79be2fd32b01703ee83a45fb068df1 /tests/auto/corelib/tools/qsizef
parentceed409b40fd5b8fe5c62ac33144e66f50b28ede (diff)
Moving relevant tests to corelib/tools
Task-number: QTBUG-21066 Change-Id: I650f8f7826b9feea7c1484f06e03e10c68ec2b65 Reviewed-on: http://codereview.qt.nokia.com/3712 Reviewed-by: Qt Sanity Bot <qt_sanity_bot@ovi.com> Reviewed-by: Sergio Ahumada <sergio.ahumada@nokia.com>
Diffstat (limited to 'tests/auto/corelib/tools/qsizef')
-rw-r--r--tests/auto/corelib/tools/qsizef/.gitignore1
-rw-r--r--tests/auto/corelib/tools/qsizef/qsizef.pro4
-rw-r--r--tests/auto/corelib/tools/qsizef/tst_qsizef.cpp181
3 files changed, 186 insertions, 0 deletions
diff --git a/tests/auto/corelib/tools/qsizef/.gitignore b/tests/auto/corelib/tools/qsizef/.gitignore
new file mode 100644
index 0000000000..f4ded487d7
--- /dev/null
+++ b/tests/auto/corelib/tools/qsizef/.gitignore
@@ -0,0 +1 @@
+tst_qsizef
diff --git a/tests/auto/corelib/tools/qsizef/qsizef.pro b/tests/auto/corelib/tools/qsizef/qsizef.pro
new file mode 100644
index 0000000000..5aa07d72a1
--- /dev/null
+++ b/tests/auto/corelib/tools/qsizef/qsizef.pro
@@ -0,0 +1,4 @@
+load(qttest_p4)
+SOURCES += tst_qsizef.cpp
+QT = core
+CONFIG += parallel_test
diff --git a/tests/auto/corelib/tools/qsizef/tst_qsizef.cpp b/tests/auto/corelib/tools/qsizef/tst_qsizef.cpp
new file mode 100644
index 0000000000..2e03a65197
--- /dev/null
+++ b/tests/auto/corelib/tools/qsizef/tst_qsizef.cpp
@@ -0,0 +1,181 @@
+/****************************************************************************
+**
+** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
+** All rights reserved.
+** Contact: Nokia Corporation (qt-info@nokia.com)
+**
+** This file is part of the test suite of the Qt 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.
+**
+** In addition, as a special exception, Nokia gives you certain additional
+** rights. These rights are described in the Nokia Qt LGPL Exception
+** version 1.1, 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.
+**
+** Other Usage
+** Alternatively, this file may be used in accordance with the terms and
+** conditions contained in a signed written agreement between you and Nokia.
+**
+**
+**
+**
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+
+#include <QtTest/QtTest>
+#include <qsize.h>
+
+Q_DECLARE_METATYPE(QSizeF)
+
+//TESTED_CLASS=
+//TESTED_FILES=corelib/tools/qsize.h corelib/tools/qsize.cpp
+
+class tst_QSizeF : public QObject {
+ Q_OBJECT
+
+public:
+ tst_QSizeF();
+ virtual ~tst_QSizeF();
+
+public slots:
+ void init();
+ void cleanup();
+
+private slots:
+ void scale();
+
+ void expandedTo();
+ void expandedTo_data();
+
+ void boundedTo_data();
+ void boundedTo();
+
+ void transpose_data();
+ void transpose();
+};
+
+tst_QSizeF::tst_QSizeF() {
+}
+
+tst_QSizeF::~tst_QSizeF() {
+}
+
+void tst_QSizeF::init() {
+}
+
+void tst_QSizeF::cleanup() {
+}
+
+void tst_QSizeF::scale() {
+ QSizeF t1(10.4, 12.8);
+ t1.scale(60.6, 60.6, Qt::IgnoreAspectRatio);
+ QCOMPARE(t1, QSizeF(60.6, 60.6));
+
+ QSizeF t2(10.4, 12.8);
+ t2.scale(43.52, 43.52, Qt::KeepAspectRatio);
+ QCOMPARE(t2, QSizeF(35.36, 43.52));
+
+ QSizeF t3(9.6, 12.48);
+ t3.scale(31.68, 31.68, Qt::KeepAspectRatioByExpanding);
+ QCOMPARE(t3, QSizeF(31.68, 41.184));
+
+ QSizeF t4(12.8, 10.4);
+ t4.scale(43.52, 43.52, Qt::KeepAspectRatio);
+ QCOMPARE(t4, QSizeF(43.52, 35.36));
+
+ QSizeF t5(12.48, 9.6);
+ t5.scale(31.68, 31.68, Qt::KeepAspectRatioByExpanding);
+ QCOMPARE(t5, QSizeF(41.184, 31.68));
+
+ QSizeF t6(0.0, 0.0);
+ t6.scale(200, 240, Qt::IgnoreAspectRatio);
+ QCOMPARE(t6, QSizeF(200, 240));
+
+ QSizeF t7(0.0, 0.0);
+ t7.scale(200, 240, Qt::KeepAspectRatio);
+ QCOMPARE(t7, QSizeF(200, 240));
+
+ QSizeF t8(0.0, 0.0);
+ t8.scale(200, 240, Qt::KeepAspectRatioByExpanding);
+ QCOMPARE(t8, QSizeF(200, 240));
+}
+
+
+void tst_QSizeF::expandedTo_data() {
+ QTest::addColumn<QSizeF>("input1");
+ QTest::addColumn<QSizeF>("input2");
+ QTest::addColumn<QSizeF>("expected");
+
+ QTest::newRow("data0") << QSizeF(10.4, 12.8) << QSizeF(6.6, 4.4) << QSizeF(10.4, 12.8);
+ QTest::newRow("data1") << QSizeF(0.0, 0.0) << QSizeF(6.6, 4.4) << QSizeF(6.6, 4.4);
+ // This should pick the highest of w,h components independently of each other,
+ // thus the result dont have to be equal to neither input1 nor input2.
+ QTest::newRow("data3") << QSizeF(6.6, 4.4) << QSizeF(4.4, 6.6) << QSizeF(6.6, 6.6);
+}
+
+void tst_QSizeF::expandedTo() {
+ QFETCH( QSizeF, input1);
+ QFETCH( QSizeF, input2);
+ QFETCH( QSizeF, expected);
+
+ QCOMPARE( input1.expandedTo(input2), expected);
+}
+
+void tst_QSizeF::boundedTo_data() {
+ QTest::addColumn<QSizeF>("input1");
+ QTest::addColumn<QSizeF>("input2");
+ QTest::addColumn<QSizeF>("expected");
+
+ QTest::newRow("data0") << QSizeF(10.4, 12.8) << QSizeF(6.6, 4.4) << QSizeF(6.6, 4.4);
+ QTest::newRow("data1") << QSizeF(0.0, 0.0) << QSizeF(6.6, 4.4) << QSizeF(0.0, 0.0);
+ // This should pick the lowest of w,h components independently of each other,
+ // thus the result dont have to be equal to neither input1 nor input2.
+ QTest::newRow("data3") << QSizeF(6.6, 4.4) << QSizeF(4.4, 6.6) << QSizeF(4.4, 4.4);
+}
+
+void tst_QSizeF::boundedTo() {
+ QFETCH( QSizeF, input1);
+ QFETCH( QSizeF, input2);
+ QFETCH( QSizeF, expected);
+
+ QCOMPARE( input1.boundedTo(input2), expected);
+}
+
+void tst_QSizeF::transpose_data() {
+ QTest::addColumn<QSizeF>("input1");
+ QTest::addColumn<QSizeF>("expected");
+
+ QTest::newRow("data0") << QSizeF(10.4, 12.8) << QSizeF(12.8, 10.4);
+ QTest::newRow("data1") << QSizeF(0.0, 0.0) << QSizeF(0.0, 0.0);
+ QTest::newRow("data3") << QSizeF(6.6, 4.4) << QSizeF(4.4, 6.6);
+}
+
+void tst_QSizeF::transpose() {
+ QFETCH( QSizeF, input1);
+ QFETCH( QSizeF, expected);
+
+ // transpose() works only inplace and does not return anything, so we must do the operation itself before the compare.
+ input1.transpose();
+ QCOMPARE(input1 , expected);
+}
+
+QTEST_APPLESS_MAIN(tst_QSizeF)
+#include "tst_qsizef.moc"