2012-01-31 04:07:58 +00:00
|
|
|
/****************************************************************************
|
|
|
|
**
|
2016-01-15 12:36:27 +00:00
|
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
|
|
** Contact: https://www.qt.io/licensing/
|
2012-01-31 04:07:58 +00:00
|
|
|
**
|
|
|
|
** This file is part of the test suite of the Qt Toolkit.
|
|
|
|
**
|
2016-01-15 12:36:27 +00:00
|
|
|
** $QT_BEGIN_LICENSE:GPL-EXCEPT$
|
2012-09-19 12:28:29 +00:00
|
|
|
** 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
|
2015-01-28 08:44:43 +00:00
|
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
2016-01-15 12:36:27 +00:00
|
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
2012-09-19 12:28:29 +00:00
|
|
|
**
|
2016-01-15 12:36:27 +00:00
|
|
|
** 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.
|
2012-01-31 04:07:58 +00:00
|
|
|
**
|
|
|
|
** $QT_END_LICENSE$
|
|
|
|
**
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <QtCore/QCoreApplication>
|
2020-11-26 16:31:50 +00:00
|
|
|
#include <QTest>
|
2012-01-31 04:07:58 +00:00
|
|
|
|
|
|
|
class tst_Counting : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
private slots:
|
2012-02-16 06:00:41 +00:00
|
|
|
// The following test functions exercise each possible combination of test
|
|
|
|
// results for two data rows.
|
2012-01-31 04:07:58 +00:00
|
|
|
void testPassPass_data();
|
|
|
|
void testPassPass();
|
|
|
|
|
|
|
|
void testPassSkip_data();
|
|
|
|
void testPassSkip();
|
|
|
|
|
|
|
|
void testPassFail_data();
|
|
|
|
void testPassFail();
|
|
|
|
|
|
|
|
void testSkipPass_data();
|
|
|
|
void testSkipPass();
|
|
|
|
|
|
|
|
void testSkipSkip_data();
|
|
|
|
void testSkipSkip();
|
|
|
|
|
|
|
|
void testSkipFail_data();
|
|
|
|
void testSkipFail();
|
|
|
|
|
|
|
|
void testFailPass_data();
|
|
|
|
void testFailPass();
|
|
|
|
|
|
|
|
void testFailSkip_data();
|
|
|
|
void testFailSkip();
|
|
|
|
|
|
|
|
void testFailFail_data();
|
|
|
|
void testFailFail();
|
|
|
|
|
2012-02-16 06:00:41 +00:00
|
|
|
// The following test functions test skips and fails in the special
|
|
|
|
// init() and cleanup() slots.
|
|
|
|
void init();
|
|
|
|
void cleanup();
|
|
|
|
void testFailInInit_data();
|
|
|
|
void testFailInInit();
|
|
|
|
void testFailInCleanup_data();
|
|
|
|
void testFailInCleanup();
|
|
|
|
void testSkipInInit_data();
|
|
|
|
void testSkipInInit();
|
|
|
|
void testSkipInCleanup_data();
|
|
|
|
void testSkipInCleanup();
|
|
|
|
|
2012-01-31 04:07:58 +00:00
|
|
|
private:
|
|
|
|
void helper();
|
|
|
|
};
|
|
|
|
|
|
|
|
enum TestResult
|
|
|
|
{
|
|
|
|
Pass,
|
|
|
|
Fail,
|
|
|
|
Skip
|
|
|
|
};
|
|
|
|
|
|
|
|
Q_DECLARE_METATYPE(TestResult);
|
|
|
|
|
|
|
|
void tst_Counting::helper()
|
|
|
|
{
|
|
|
|
QFETCH(TestResult, result);
|
|
|
|
|
|
|
|
switch (result) {
|
|
|
|
case Pass:
|
|
|
|
QVERIFY(true);
|
2012-03-01 05:14:18 +00:00
|
|
|
QCOMPARE(2 + 1, 3);
|
2012-01-31 04:07:58 +00:00
|
|
|
break;
|
|
|
|
case Fail:
|
|
|
|
QVERIFY(false);
|
|
|
|
break;
|
|
|
|
case Skip:
|
|
|
|
QSKIP("Skipping");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testPassPass_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<TestResult>("result");
|
|
|
|
QTest::newRow("row 1") << Pass;
|
|
|
|
QTest::newRow("row 2") << Pass;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testPassPass()
|
|
|
|
{
|
|
|
|
helper();
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testPassSkip_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<TestResult>("result");
|
|
|
|
QTest::newRow("row 1") << Pass;
|
|
|
|
QTest::newRow("row 2") << Skip;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testPassSkip()
|
|
|
|
{
|
|
|
|
helper();
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testPassFail_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<TestResult>("result");
|
|
|
|
QTest::newRow("row 1") << Pass;
|
|
|
|
QTest::newRow("row 2") << Fail;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testPassFail()
|
|
|
|
{
|
|
|
|
helper();
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testSkipPass_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<TestResult>("result");
|
|
|
|
QTest::newRow("row 1") << Skip;
|
|
|
|
QTest::newRow("row 2") << Pass;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testSkipPass()
|
|
|
|
{
|
|
|
|
helper();
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testSkipSkip_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<TestResult>("result");
|
|
|
|
QTest::newRow("row 1") << Skip;
|
|
|
|
QTest::newRow("row 2") << Skip;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testSkipSkip()
|
|
|
|
{
|
|
|
|
helper();
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testSkipFail_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<TestResult>("result");
|
|
|
|
QTest::newRow("row 1") << Skip;
|
|
|
|
QTest::newRow("row 2") << Fail;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testSkipFail()
|
|
|
|
{
|
|
|
|
helper();
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testFailPass_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<TestResult>("result");
|
|
|
|
QTest::newRow("row 1") << Fail;
|
|
|
|
QTest::newRow("row 2") << Pass;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testFailPass()
|
|
|
|
{
|
|
|
|
helper();
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testFailSkip_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<TestResult>("result");
|
|
|
|
QTest::newRow("row 1") << Fail;
|
|
|
|
QTest::newRow("row 2") << Skip;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testFailSkip()
|
|
|
|
{
|
|
|
|
helper();
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testFailFail_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<TestResult>("result");
|
|
|
|
QTest::newRow("row 1") << Fail;
|
|
|
|
QTest::newRow("row 2") << Fail;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testFailFail()
|
|
|
|
{
|
|
|
|
helper();
|
|
|
|
}
|
|
|
|
|
2012-02-16 06:00:41 +00:00
|
|
|
void tst_Counting::init()
|
|
|
|
{
|
|
|
|
if (strcmp(QTest::currentTestFunction(), "testFailInInit") == 0 && strcmp(QTest::currentDataTag(), "fail") == 0)
|
|
|
|
QFAIL("Fail in init()");
|
|
|
|
else if (strcmp(QTest::currentTestFunction(), "testSkipInInit") == 0 && strcmp(QTest::currentDataTag(), "skip") == 0)
|
|
|
|
QSKIP("Skip in init()");
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::cleanup()
|
|
|
|
{
|
|
|
|
if (strcmp(QTest::currentTestFunction(), "testFailInCleanup") == 0 && strcmp(QTest::currentDataTag(), "fail") == 0)
|
|
|
|
QFAIL("Fail in cleanup()");
|
|
|
|
else if (strcmp(QTest::currentTestFunction(), "testSkipInCleanup") == 0 && strcmp(QTest::currentDataTag(), "skip") == 0)
|
|
|
|
QSKIP("Skip in cleanup()");
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testFailInInit_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<bool>("dummy");
|
|
|
|
QTest::newRow("before") << true;
|
|
|
|
QTest::newRow("fail") << true;
|
|
|
|
QTest::newRow("after") << true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testFailInInit()
|
|
|
|
{
|
|
|
|
if (strcmp(QTest::currentDataTag(), "fail") == 0)
|
|
|
|
QFAIL("This test function should have been skipped due to QFAIL in init()");
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testFailInCleanup_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<bool>("dummy");
|
|
|
|
QTest::newRow("before") << true;
|
|
|
|
QTest::newRow("fail") << true;
|
|
|
|
QTest::newRow("after") << true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testFailInCleanup()
|
|
|
|
{
|
|
|
|
if (strcmp(QTest::currentDataTag(), "fail") == 0)
|
|
|
|
qDebug() << "This test function should execute and then QFAIL in cleanup()";
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testSkipInInit_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<bool>("dummy");
|
|
|
|
QTest::newRow("before") << true;
|
|
|
|
QTest::newRow("skip") << true;
|
|
|
|
QTest::newRow("after") << true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testSkipInInit()
|
|
|
|
{
|
|
|
|
if (strcmp(QTest::currentDataTag(), "skip") == 0)
|
|
|
|
QFAIL("This test function should have been skipped due to QSKIP in init()");
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testSkipInCleanup_data()
|
|
|
|
{
|
|
|
|
QTest::addColumn<bool>("dummy");
|
|
|
|
QTest::newRow("before") << true;
|
|
|
|
QTest::newRow("skip") << true;
|
|
|
|
QTest::newRow("after") << true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void tst_Counting::testSkipInCleanup()
|
|
|
|
{
|
|
|
|
if (strcmp(QTest::currentDataTag(), "skip") == 0)
|
|
|
|
qDebug() << "This test function should execute and then QSKIP in cleanup()";
|
|
|
|
}
|
|
|
|
|
2020-02-06 11:07:04 +00:00
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
#ifdef TESTLIB_VERBOSITY_ARG
|
|
|
|
std::vector<const char*> args(argv, argv + argc);
|
|
|
|
args.push_back(QT_STRINGIFY(TESTLIB_VERBOSITY_ARG));
|
2020-10-20 12:26:43 +00:00
|
|
|
argc = int(args.size());
|
2020-02-06 11:07:04 +00:00
|
|
|
argv = const_cast<char**>(&args[0]);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
QTEST_MAIN_IMPL(tst_Counting)
|
|
|
|
}
|
2012-01-31 04:07:58 +00:00
|
|
|
#include "tst_counting.moc"
|