diff options
author | Konstantin Podsvirov <konstantin@podsvirov.pro> | 2017-08-28 14:25:27 +0300 |
---|---|---|
committer | Konstantin Podsvirov <konstantin@podsvirov.pro> | 2017-11-13 14:50:07 +0000 |
commit | 1f3eded578314fb903bf50447d614fd314bd0eec (patch) | |
tree | ddf8f4b80dab5386c8c3f881c46b940173e3c17a /tests/auto/installer | |
parent | ee24c7aefce6acbcac7a51f7c8c53c84ecdc7eca (diff) |
Allow comparing non-numeric versions
Changes:
- Improve KDUpdater::compareVersion method;
- Add tst_CompareVersion test.
Task-number: QTIFW-948
Change-Id: If64f807cfb04e56d2bdd5fa250f456631df3f239
Reviewed-by: André Hartmann <aha_1980@gmx.de>
Reviewed-by: Kai Koehne <kai.koehne@qt.io>
Reviewed-by: Katja Marttila <katja.marttila@qt.io>
Diffstat (limited to 'tests/auto/installer')
-rw-r--r-- | tests/auto/installer/compareversion/compareversion.pro | 6 | ||||
-rw-r--r-- | tests/auto/installer/compareversion/tst_compareversion.cpp | 93 | ||||
-rw-r--r-- | tests/auto/installer/installer.pro | 1 |
3 files changed, 100 insertions, 0 deletions
diff --git a/tests/auto/installer/compareversion/compareversion.pro b/tests/auto/installer/compareversion/compareversion.pro new file mode 100644 index 000000000..4f941df4a --- /dev/null +++ b/tests/auto/installer/compareversion/compareversion.pro @@ -0,0 +1,6 @@ +include(../../qttest.pri) + +QT -= gui + +SOURCES += tst_compareversion.cpp + diff --git a/tests/auto/installer/compareversion/tst_compareversion.cpp b/tests/auto/installer/compareversion/tst_compareversion.cpp new file mode 100644 index 000000000..24ebe9ba6 --- /dev/null +++ b/tests/auto/installer/compareversion/tst_compareversion.cpp @@ -0,0 +1,93 @@ +/************************************************************************** +** +** Copyright (C) 2017 Konstantin Podsvirov <konstantin@podsvirov.pro> +** Contact: https://www.qt.io/licensing/ +** +** This file is part of the Qt Installer Framework. +** +** $QT_BEGIN_LICENSE:GPL-EXCEPT$ +** 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 The Qt Company. For licensing terms +** and conditions see https://www.qt.io/terms-conditions. For further +** information use the contact form at https://www.qt.io/contact-us. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3 as published by the Free Software +** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT +** included in the packaging of this file. Please review the following +** information to ensure the GNU General Public License requirements will +** be met: https://www.gnu.org/licenses/gpl-3.0.html. +** +** $QT_END_LICENSE$ +** +**************************************************************************/ + +#include "updater.h" + +#include <QTest> + +class tst_CompareVersion : public QObject +{ + Q_OBJECT + +private slots: + void compareVersion(); + void compareVersionX(); + void compareVersionAll(); + void compareVersionExtra(); +}; + +void tst_CompareVersion::compareVersion() +{ + QCOMPARE(KDUpdater::compareVersion("2.0", "2.1"), -1); + QCOMPARE(KDUpdater::compareVersion("2.1", "2.0"), +1); + QCOMPARE(KDUpdater::compareVersion("2.0", "2.0"), 0); + QCOMPARE(KDUpdater::compareVersion("2.1", "2.1"), 0); + + QCOMPARE(KDUpdater::compareVersion("2.0.12.4", "2.1.10.4"), -1); +} + +void tst_CompareVersion::compareVersionX() +{ + QCOMPARE(KDUpdater::compareVersion("2.0", "2.x"), 0); + QCOMPARE(KDUpdater::compareVersion("2.x", "2.0"), 0); + + QCOMPARE(KDUpdater::compareVersion("2.0.12.x", "2.0.x"), 0); + QCOMPARE(KDUpdater::compareVersion("2.1.12.x", "2.0.x"), +1); + QCOMPARE(KDUpdater::compareVersion("2.1.12.x", "2.x"), 0); + QCOMPARE(KDUpdater::compareVersion("2.x", "2.1.12.x"), 0); +} + +void tst_CompareVersion::compareVersionAll() +{ + QCOMPARE(KDUpdater::compareVersion("version-1", "version-2"), -1); + + QCOMPARE(KDUpdater::compareVersion("v2.0", "v2.x"), 0); + QCOMPARE(KDUpdater::compareVersion("v2.x", "v2.0"), 0); + + QCOMPARE(KDUpdater::compareVersion("v2.0-alpha", "v2.0-alpha"), 0); + + QCOMPARE(KDUpdater::compareVersion("v2.0-alpha", "v2.0-beta"), -1); + QCOMPARE(KDUpdater::compareVersion("v2.0-beta", "v2.0-alpha"), +1); + + QCOMPARE(KDUpdater::compareVersion("v2.0-rc1", "v2.0-beta"), +1); + QCOMPARE(KDUpdater::compareVersion("v2.0-rc1", "v2.0-rc2"), -1); + QCOMPARE(KDUpdater::compareVersion("v2.0-rc2", "v2.0-rc11"), -1); + QCOMPARE(KDUpdater::compareVersion("v2.0-rc22", "v2.0-rc2"), +1); + + QCOMPARE(KDUpdater::compareVersion("v2.0", "v2.0-rc3"), +1); +} + +void tst_CompareVersion::compareVersionExtra() +{ + QCOMPARE(KDUpdater::compareVersion("OpenSSL_1_0_2k", "OpenSSL_1_0_2l"), -1); + QCOMPARE(KDUpdater::compareVersion("OpenSSL_1_1_0f", "OpenSSL_1_0_2k"), +1); +} + +QTEST_MAIN(tst_CompareVersion) + +#include "tst_compareversion.moc" diff --git a/tests/auto/installer/installer.pro b/tests/auto/installer/installer.pro index ba2dd0244..01a26da47 100644 --- a/tests/auto/installer/installer.pro +++ b/tests/auto/installer/installer.pro @@ -3,6 +3,7 @@ TEMPLATE = subdirs SUBDIRS += \ settings \ repository \ + compareversion\ componentmodel \ fakestopprocessforupdateoperation \ messageboxhandler \ |