source: trunk/src/testlib/qtestlog.cpp@ 5

Last change on this file since 5 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 9.9 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information ([email protected])
5**
6** This file is part of the QtTest module of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at [email protected].
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42#include "QtTest/qtestassert.h"
43
44#include "QtTest/private/qtestlog_p.h"
45#include "QtTest/private/qtestresult_p.h"
46#include "QtTest/private/qabstracttestlogger_p.h"
47#include "QtTest/private/qplaintestlogger_p.h"
48#include "QtTest/private/qxmltestlogger_p.h"
49
50#include <QtCore/qatomic.h>
51#include <QtCore/qbytearray.h>
52
53#include <stdlib.h>
54#include <string.h>
55#include <limits.h>
56
57QT_BEGIN_NAMESPACE
58
59namespace QTest {
60
61 struct IgnoreResultList
62 {
63 inline IgnoreResultList(QtMsgType tp, const char *message)
64 : type(tp), next(0)
65 { msg = qstrdup(message); }
66 inline ~IgnoreResultList()
67 { delete [] msg; }
68
69 static inline void clearList(IgnoreResultList *&list)
70 {
71 while (list) {
72 IgnoreResultList *current = list;
73 list = list->next;
74 delete current;
75 }
76 }
77
78 QtMsgType type;
79 char *msg;
80 IgnoreResultList *next;
81 };
82
83 static IgnoreResultList *ignoreResultList = 0;
84
85 static QTestLog::LogMode logMode = QTestLog::Plain;
86 static int verbosity = 0;
87 static int maxWarnings = 2002;
88
89 static QAbstractTestLogger *testLogger = 0;
90 static const char *outFile = 0;
91
92 static QtMsgHandler oldMessageHandler;
93
94 static bool handleIgnoredMessage(QtMsgType type, const char *msg)
95 {
96 IgnoreResultList *last = 0;
97 IgnoreResultList *list = ignoreResultList;
98 while (list) {
99 if (list->type == type && strcmp(msg, list->msg) == 0) {
100 // remove the item from the list
101 if (last)
102 last->next = list->next;
103 else if (list->next)
104 ignoreResultList = list->next;
105 else
106 ignoreResultList = 0;
107
108 delete list;
109 return true;
110 }
111
112 last = list;
113 list = list->next;
114 }
115 return false;
116 }
117
118 static void messageHandler(QtMsgType type, const char *msg)
119 {
120 static QBasicAtomicInt counter = Q_BASIC_ATOMIC_INITIALIZER(QTest::maxWarnings);
121
122 if (!msg || !QTest::testLogger) {