Qt 4.8
qtestresult_p.h
Go to the documentation of this file.
1 /****************************************************************************
2 **
3 ** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
4 ** Contact: http://www.qt-project.org/legal
5 **
6 ** This file is part of the QtTest module of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and Digia. For licensing terms and
14 ** conditions see http://qt.digia.com/licensing. For further information
15 ** use the contact form at http://qt.digia.com/contact-us.
16 **
17 ** GNU Lesser General Public License Usage
18 ** Alternatively, this file may be used under the terms of the GNU Lesser
19 ** General Public License version 2.1 as published by the Free Software
20 ** Foundation and appearing in the file LICENSE.LGPL included in the
21 ** packaging of this file. Please review the following information to
22 ** ensure the GNU Lesser General Public License version 2.1 requirements
23 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
24 **
25 ** In addition, as a special exception, Digia gives you certain additional
26 ** rights. These rights are described in the Digia Qt LGPL Exception
27 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
28 **
29 ** GNU General Public License Usage
30 ** Alternatively, this file may be used under the terms of the GNU
31 ** General Public License version 3.0 as published by the Free Software
32 ** Foundation and appearing in the file LICENSE.GPL included in the
33 ** packaging of this file. Please review the following information to
34 ** ensure the GNU General Public License version 3.0 requirements will be
35 ** met: http://www.gnu.org/copyleft/gpl.html.
36 **
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41 
42 #ifndef QTESTRESULT_P_H
43 #define QTESTRESULT_P_H
44 
45 //
46 // W A R N I N G
47 // -------------
48 //
49 // This file is not part of the Qt API. It exists purely as an
50 // implementation detail. This header file may change from version to
51 // version without notice, or even be removed.
52 //
53 // We mean it.
54 //
55 
56 #include <QtTest/qtest_global.h>
57 
59 
60 class QTestResultPrivate;
61 class QTestData;
62 
64 {
65 public:
66  enum TestLocation { NoWhere = 0, DataFunc = 1, InitFunc = 2, Func = 3, CleanupFunc = 4 };
67 
68  static const char *currentTestObjectName();
69  static bool currentTestFailed();
70  static bool allDataPassed();
71  static QTestData *currentTestData();
73  static const char *currentTestFunction();
74  static TestLocation currentTestLocation();
75  static const char *currentDataTag();
76  static const char *currentGlobalDataTag();
77  static void finishedCurrentTestFunction();
78  static void reset();
79 
80  static int passCount();
81  static int failCount();
82  static int skipCount();
83 
84  static void ignoreMessage(QtMsgType type, const char *msg);
85 
86  static void addFailure(const char *message, const char *file, int line);
87  static bool compare(bool success, const char *msg, const char *file, int line);
88  static bool compare(bool success, const char *msg, char *val1, char *val2,
89  const char *actual, const char *expected, const char *file, int line);
90 
91  static void setCurrentGlobalTestData(QTestData *data);
92  static void setCurrentTestData(QTestData *data);
93  static void setCurrentTestFunction(const char *func);
94  static void setCurrentTestLocation(TestLocation loc);
95  static void setCurrentTestObject(const char *name);
96  static void addSkip(const char *message, QTest::SkipMode mode,
97  const char *file, int line);
98  static bool expectFail(const char *dataIndex, const char *comment,
99  QTest::TestFailMode mode, const char *file, int line);
100  static bool verify(bool statement, const char *statementStr, const char *extraInfo,
101  const char *file, int line);
102  static bool testFailed();
103  static void setSkipCurrentTest(bool value);
104  static bool skipCurrentTest();
105 
106  static void setCurrentAppName(const char *appName);
107  static const char *currentAppName();
108 
109 private:
111 };
112 
114 
115 #endif
#define Q_TESTLIB_EXPORT
Definition: qtest_global.h:56
int type
Definition: qmetatype.cpp:239
#define QT_END_NAMESPACE
This macro expands to.
Definition: qglobal.h:90
static const char * currentAppName
Definition: qtestresult.cpp:72
Q_TESTLIB_EXPORT const char * currentTestFunction()
Returns the name of the test function that is currently executed.
Definition: qtestcase.cpp:2230
Q_TESTLIB_EXPORT void ignoreMessage(QtMsgType type, const char *message)
Ignores messages created by qDebug() or qWarning().
Definition: qtestcase.cpp:2123
SkipMode
This enum describes the modes for skipping tests during execution of the test data.
Definition: qtest_global.h:82
static bool skipCurrentTest
Definition: qtestresult.cpp:62
Q_CORE_EXPORT QTextStream & reset(QTextStream &s)
#define Q_DISABLE_COPY(Class)
Disables the use of copy constructors and assignment operators for the given Class.
Definition: qglobal.h:2523
QtMsgType
This enum describes the messages that can be sent to a message handler (QtMsgHandler).
Definition: qglobal.h:1881
#define QT_BEGIN_NAMESPACE
This macro expands to.
Definition: qglobal.h:89
static bool compare(const QVariant::Private *a, const QVariant::Private *b)
Compares a to b.
Definition: qvariant.cpp:383
const char * name
static const char * data(const QByteArray &arr)
Q_TESTLIB_EXPORT const char * currentDataTag()
Returns the name of the current test data.
Definition: qtestcase.cpp:2239
TestFailMode
This enum describes the modes for handling an expected failure of the QVERIFY() or QCOMPARE() macros...
Definition: qtest_global.h:83
static QString appName
static QTestData * currentTestData
Definition: qtestresult.cpp:56
Q_TESTLIB_EXPORT bool currentTestFailed()
Returns true if the current test function failed, otherwise false.
Definition: qtestcase.cpp:2247
static const char * currentTestObjectName
Definition: qtestresult.cpp:59
static QTestData * currentGlobalTestData
Definition: qtestresult.cpp:57