Improve pair-like class handling in tests
Currently when doing comparison with pair-like classes the fallback toString method is called which returns a Q_NULLPTR thus not allowing proper diagnostic of the values that triggered an error. This patch adds support for QPair and std::pair to improve the tests output readability. [ChangeLog][QtTest][QCOMPARE] Now outputs contents of QPair and std::pair on failure. Change-Id: Ib0b4aad7640590d56275b6f1306fb9fb39fa81bc Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
This commit is contained in:
parent
6f41600422
commit
c608ffc56a
@ -259,6 +259,22 @@ namespace QTest
|
|||||||
return Internal::toString(t);
|
return Internal::toString(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename T1, typename T2>
|
||||||
|
inline char *toString(const QPair<T1, T2> &pair)
|
||||||
|
{
|
||||||
|
const QScopedArrayPointer<char> first(toString(pair.first));
|
||||||
|
const QScopedArrayPointer<char> second(toString(pair.second));
|
||||||
|
return toString(QString::asprintf("QPair(%s,%s)", first.data(), second.data()));
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T1, typename T2>
|
||||||
|
inline char *toString(const std::pair<T1, T2> &pair)
|
||||||
|
{
|
||||||
|
const QScopedArrayPointer<char> first(toString(pair.first));
|
||||||
|
const QScopedArrayPointer<char> second(toString(pair.second));
|
||||||
|
return toString(QString::asprintf("std::pair(%s,%s)", first.data(), second.data()));
|
||||||
|
}
|
||||||
|
|
||||||
Q_TESTLIB_EXPORT char *toHexRepresentation(const char *ba, int length);
|
Q_TESTLIB_EXPORT char *toHexRepresentation(const char *ba, int length);
|
||||||
Q_TESTLIB_EXPORT char *toPrettyCString(const char *unicode, int length);
|
Q_TESTLIB_EXPORT char *toPrettyCString(const char *unicode, int length);
|
||||||
Q_TESTLIB_EXPORT char *toPrettyUnicode(const ushort *unicode, int length);
|
Q_TESTLIB_EXPORT char *toPrettyUnicode(const ushort *unicode, int length);
|
||||||
|
@ -0,0 +1,30 @@
|
|||||||
|
<Environment>
|
||||||
|
<QtVersion>@INSERT_QT_VERSION_HERE@</QtVersion>
|
||||||
|
<QtBuild/>
|
||||||
|
<QTestVersion>@INSERT_QT_VERSION_HERE@</QTestVersion>
|
||||||
|
</Environment>
|
||||||
|
<TestFunction name="initTestCase">
|
||||||
|
<Incident type="pass" file="" line="0" />
|
||||||
|
<Duration msecs="0"/>
|
||||||
|
</TestFunction>
|
||||||
|
<TestFunction name="testQPair">
|
||||||
|
<Incident type="fail" file="../../../qt5/qtbase_fixItemData/tests/auto/testlib/selftests/pairdiagnostics/tst_pairdiagnostics.cpp" line="51">
|
||||||
|
<Description><![CDATA[Compared values are not the same
|
||||||
|
Actual (pair1): "QPair(1,1)"
|
||||||
|
Expected (pair2): "QPair(1,2)"]]></Description>
|
||||||
|
</Incident>
|
||||||
|
<Duration msecs="0"/>
|
||||||
|
</TestFunction>
|
||||||
|
<TestFunction name="testStdPair">
|
||||||
|
<Incident type="fail" file="../../../qt5/qtbase_fixItemData/tests/auto/testlib/selftests/pairdiagnostics/tst_pairdiagnostics.cpp" line="58">
|
||||||
|
<Description><![CDATA[Compared values are not the same
|
||||||
|
Actual (pair1): "std::pair(1,1)"
|
||||||
|
Expected (pair2): "std::pair(1,2)"]]></Description>
|
||||||
|
</Incident>
|
||||||
|
<Duration msecs="0"/>
|
||||||
|
</TestFunction>
|
||||||
|
<TestFunction name="cleanupTestCase">
|
||||||
|
<Incident type="pass" file="" line="0" />
|
||||||
|
<Duration msecs="0"/>
|
||||||
|
</TestFunction>
|
||||||
|
<Duration msecs="0"/>
|
@ -0,0 +1,12 @@
|
|||||||
|
##teamcity[testSuiteStarted name='tst_PairDiagnostics']
|
||||||
|
##teamcity[testStarted name='initTestCase()']
|
||||||
|
##teamcity[testFinished name='initTestCase()']
|
||||||
|
##teamcity[testStarted name='testQPair()']
|
||||||
|
##teamcity[testFailed name='testQPair()' message='Failure! |[Loc: ../../../qt5/qtbase_fixItemData/tests/auto/testlib/selftests/pairdiagnostics/tst_pairdiagnostics.cpp(51)|]' details='Compared values are not the same|n Actual (pair1): "QPair(1,1)"|n Expected (pair2): "QPair(1,2)"']
|
||||||
|
##teamcity[testFinished name='testQPair()']
|
||||||
|
##teamcity[testStarted name='testStdPair()']
|
||||||
|
##teamcity[testFailed name='testStdPair()' message='Failure! |[Loc: ../../../qt5/qtbase_fixItemData/tests/auto/testlib/selftests/pairdiagnostics/tst_pairdiagnostics.cpp(58)|]' details='Compared values are not the same|n Actual (pair1): "std::pair(1,1)"|n Expected (pair2): "std::pair(1,2)"']
|
||||||
|
##teamcity[testFinished name='testStdPair()']
|
||||||
|
##teamcity[testStarted name='cleanupTestCase()']
|
||||||
|
##teamcity[testFinished name='cleanupTestCase()']
|
||||||
|
##teamcity[testSuiteFinished name='tst_PairDiagnostics']
|
14
tests/auto/testlib/selftests/expected_pairdiagnostics.txt
Normal file
14
tests/auto/testlib/selftests/expected_pairdiagnostics.txt
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
********* Start testing of tst_PairDiagnostics *********
|
||||||
|
Config: Using QtTest library @INSERT_QT_VERSION_HERE@, Qt @INSERT_QT_VERSION_HERE@
|
||||||
|
PASS : tst_PairDiagnostics::initTestCase()
|
||||||
|
FAIL! : tst_PairDiagnostics::testQPair() Compared values are not the same
|
||||||
|
Actual (pair1): "QPair(1,1)"
|
||||||
|
Expected (pair2): "QPair(1,2)"
|
||||||
|
Loc: [../../../qt5/qtbase_fixItemData/tests/auto/testlib/selftests/pairdiagnostics/tst_pairdiagnostics.cpp(51)]
|
||||||
|
FAIL! : tst_PairDiagnostics::testStdPair() Compared values are not the same
|
||||||
|
Actual (pair1): "std::pair(1,1)"
|
||||||
|
Expected (pair2): "std::pair(1,2)"
|
||||||
|
Loc: [../../../qt5/qtbase_fixItemData/tests/auto/testlib/selftests/pairdiagnostics/tst_pairdiagnostics.cpp(58)]
|
||||||
|
PASS : tst_PairDiagnostics::cleanupTestCase()
|
||||||
|
Totals: 2 passed, 2 failed, 0 skipped, 0 blacklisted, 1ms
|
||||||
|
********* Finished testing of tst_PairDiagnostics *********
|
33
tests/auto/testlib/selftests/expected_pairdiagnostics.xml
Normal file
33
tests/auto/testlib/selftests/expected_pairdiagnostics.xml
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<TestCase name="tst_PairDiagnostics">
|
||||||
|
<Environment>
|
||||||
|
<QtVersion>@INSERT_QT_VERSION_HERE@</QtVersion>
|
||||||
|
<QtBuild/>
|
||||||
|
<QTestVersion>@INSERT_QT_VERSION_HERE@</QTestVersion>
|
||||||
|
</Environment>
|
||||||
|
<TestFunction name="initTestCase">
|
||||||
|
<Incident type="pass" file="" line="0" />
|
||||||
|
<Duration msecs="0.680795"/>
|
||||||
|
</TestFunction>
|
||||||
|
<TestFunction name="testQPair">
|
||||||
|
<Incident type="fail" file="../../../qt5/qtbase_fixItemData/tests/auto/testlib/selftests/pairdiagnostics/tst_pairdiagnostics.cpp" line="51">
|
||||||
|
<Description><![CDATA[Compared values are not the same
|
||||||
|
Actual (pair1): "QPair(1,1)"
|
||||||
|
Expected (pair2): "QPair(1,2)"]]></Description>
|
||||||
|
</Incident>
|
||||||
|
<Duration msecs="0.085705"/>
|
||||||
|
</TestFunction>
|
||||||
|
<TestFunction name="testStdPair">
|
||||||
|
<Incident type="fail" file="../../../qt5/qtbase_fixItemData/tests/auto/testlib/selftests/pairdiagnostics/tst_pairdiagnostics.cpp" line="58">
|
||||||
|
<Description><![CDATA[Compared values are not the same
|
||||||
|
Actual (pair1): "std::pair(1,1)"
|
||||||
|
Expected (pair2): "std::pair(1,2)"]]></Description>
|
||||||
|
</Incident>
|
||||||
|
<Duration msecs="0.030780"/>
|
||||||
|
</TestFunction>
|
||||||
|
<TestFunction name="cleanupTestCase">
|
||||||
|
<Incident type="pass" file="" line="0" />
|
||||||
|
<Duration msecs="0.039052"/>
|
||||||
|
</TestFunction>
|
||||||
|
<Duration msecs="0.995227"/>
|
||||||
|
</TestCase>
|
@ -0,0 +1,21 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<testsuite errors="0" failures="2" tests="4" name="tst_PairDiagnostics">
|
||||||
|
<properties>
|
||||||
|
<property value="@INSERT_QT_VERSION_HERE@" name="QTestVersion"/>
|
||||||
|
<property value="@INSERT_QT_VERSION_HERE@" name="QtVersion"/>
|
||||||
|
<property value="" name="QtBuild"/>
|
||||||
|
</properties>
|
||||||
|
<testcase result="pass" name="initTestCase"/>
|
||||||
|
<testcase result="fail" name="testQPair">
|
||||||
|
<failure message="Compared values are not the same
|
||||||
|
Actual (pair1): "QPair(1,1)"
|
||||||
|
Expected (pair2): "QPair(1,2)"" result="fail"/>
|
||||||
|
</testcase>
|
||||||
|
<testcase result="fail" name="testStdPair">
|
||||||
|
<failure message="Compared values are not the same
|
||||||
|
Actual (pair1): "std::pair(1,1)"
|
||||||
|
Expected (pair2): "std::pair(1,2)"" result="fail"/>
|
||||||
|
</testcase>
|
||||||
|
<testcase result="pass" name="cleanupTestCase"/>
|
||||||
|
<system-err/>
|
||||||
|
</testsuite>
|
@ -0,0 +1,6 @@
|
|||||||
|
SOURCES += tst_pairdiagnostics.cpp
|
||||||
|
QT = core testlib
|
||||||
|
|
||||||
|
CONFIG -= app_bundle debug_and_release_target
|
||||||
|
|
||||||
|
TARGET = pairdiagnostics
|
@ -0,0 +1,63 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
**
|
||||||
|
** Copyright (C) 2016 The Qt Company Ltd.
|
||||||
|
** Contact: https://www.qt.io/licensing/
|
||||||
|
**
|
||||||
|
** This file is part of the test suite of the Qt Toolkit.
|
||||||
|
**
|
||||||
|
** $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$
|
||||||
|
**
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
// Make sure we get a real Q_ASSERT even in release builds
|
||||||
|
#ifdef QT_NO_DEBUG
|
||||||
|
# undef QT_NO_DEBUG
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <QtCore/QCoreApplication>
|
||||||
|
#include <QtCore/QPair>
|
||||||
|
#include <QtTest/QtTest>
|
||||||
|
|
||||||
|
class tst_PairDiagnostics: public QObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void testQPair() const;
|
||||||
|
void testStdPair() const;
|
||||||
|
};
|
||||||
|
|
||||||
|
void tst_PairDiagnostics::testQPair() const
|
||||||
|
{
|
||||||
|
QPair<int, int> pair1 = qMakePair(1, 1);
|
||||||
|
QPair<int, int> pair2 = qMakePair(1, 2);
|
||||||
|
QCOMPARE(pair1, pair2);
|
||||||
|
}
|
||||||
|
|
||||||
|
void tst_PairDiagnostics::testStdPair() const
|
||||||
|
{
|
||||||
|
std::pair<int, int> pair1 = std::make_pair(1, 1);
|
||||||
|
std::pair<int, int> pair2 = std::make_pair(1, 2);
|
||||||
|
QCOMPARE(pair1, pair2);
|
||||||
|
}
|
||||||
|
|
||||||
|
QTEST_MAIN(tst_PairDiagnostics)
|
||||||
|
|
||||||
|
#include "tst_pairdiagnostics.moc"
|
@ -28,6 +28,7 @@ SUBPROGRAMS = \
|
|||||||
longstring \
|
longstring \
|
||||||
maxwarnings \
|
maxwarnings \
|
||||||
multiexec \
|
multiexec \
|
||||||
|
pairdiagnostics \
|
||||||
printdatatags \
|
printdatatags \
|
||||||
printdatatagswithglobaltags \
|
printdatatagswithglobaltags \
|
||||||
qexecstringlist \
|
qexecstringlist \
|
||||||
|
@ -115,6 +115,11 @@
|
|||||||
<file>expected_maxwarnings.xml</file>
|
<file>expected_maxwarnings.xml</file>
|
||||||
<file>expected_maxwarnings.xunitxml</file>
|
<file>expected_maxwarnings.xunitxml</file>
|
||||||
<file>expected_multiexec.txt</file>
|
<file>expected_multiexec.txt</file>
|
||||||
|
<file>expected_pairdiagnostics.lightxml</file>
|
||||||
|
<file>expected_pairdiagnostics.teamcity</file>
|
||||||
|
<file>expected_pairdiagnostics.txt</file>
|
||||||
|
<file>expected_pairdiagnostics.xml</file>
|
||||||
|
<file>expected_pairdiagnostics.xunitxml</file>
|
||||||
<file>expected_printdatatags.txt</file>
|
<file>expected_printdatatags.txt</file>
|
||||||
<file>expected_printdatatagswithglobaltags.txt</file>
|
<file>expected_printdatatagswithglobaltags.txt</file>
|
||||||
<file>expected_qexecstringlist.txt</file>
|
<file>expected_qexecstringlist.txt</file>
|
||||||
|
@ -395,6 +395,7 @@ void tst_Selftests::runSubTest_data()
|
|||||||
<< "longstring"
|
<< "longstring"
|
||||||
<< "maxwarnings"
|
<< "maxwarnings"
|
||||||
<< "multiexec"
|
<< "multiexec"
|
||||||
|
<< "pairdiagnostics"
|
||||||
<< "printdatatags"
|
<< "printdatatags"
|
||||||
<< "printdatatagswithglobaltags"
|
<< "printdatatagswithglobaltags"
|
||||||
<< "qexecstringlist"
|
<< "qexecstringlist"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user