Qt 4.8
qtestfilelogger.cpp
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 #include "qtestfilelogger.h"
43 #include "qtestassert.h"
44 #include "QtTest/private/qtestlog_p.h"
45 #include "QtTest/private/qtestresult_p.h"
46 
47 #include <QtCore/qdir.h>
48 
49 #include <stdlib.h>
50 #include <stdio.h>
51 
53 
54 namespace QTest
55 {
56  static FILE *stream = 0;
57 }
58 
60 {
61 }
62 
64 {
65  if(QTest::stream)
66  fclose(QTest::stream);
67 
68  QTest::stream = 0;
69 }
70 
72 {
73  char filename[100];
74  int index = 0;
75 #if defined(Q_OS_SYMBIAN)
77  index = ba.length();
78  QTest::qt_snprintf(filename, sizeof(filename), "%s%s.log",
80 #else
81  QTest::qt_snprintf(filename, sizeof(filename), "%s.log",
83 #endif
84 
85  // Keep filenames simple
86  for (uint i = index; i < sizeof(filename) && filename[i]; ++i) {
87  char& c = filename[i];
88  if (!((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')
89  || (c >= '0' && c <= '9') || c == '-' || c == '.')) {
90  c = '_';
91  }
92  }
93 
94 #if defined(_MSC_VER) && _MSC_VER >= 1400 && !defined(Q_OS_WINCE)
95  if (::fopen_s(&QTest::stream, filename, "wt")) {
96 #else
97  QTest::stream = ::fopen(filename, "wt");
98  if (!QTest::stream) {
99 #endif
100  printf("Unable to open file for simple logging: %s", filename);
101  ::exit(1);
102  }
103 }
104 
105 void QTestFileLogger::flush(const char *msg)
106 {
108 
109  ::fputs(msg, QTest::stream);
110  ::fflush(QTest::stream);
111 }
112 
114 
unsigned char c[8]
Definition: qnumeric_p.h:62
#define QT_END_NAMESPACE
This macro expands to.
Definition: qglobal.h:90
The QByteArray class provides an array of bytes.
Definition: qbytearray.h:135
The QString class provides a Unicode character string.
Definition: qstring.h:83
static QChar separator()
Returns the native directory separator: "/" under Unix (including Mac OS X) and "\\" under Windows...
Definition: qdir.cpp:1831
#define QT_BEGIN_NAMESPACE
This macro expands to.
Definition: qglobal.h:89
static const char * currentTestObjectName()
static FILE * stream
unsigned int uint
Definition: qglobal.h:996
void flush(const char *msg)
int length() const
Same as size().
Definition: qbytearray.h:356
const char * constData() const
Returns a pointer to the data stored in the byte array.
Definition: qbytearray.h:433
int Q_TESTLIB_EXPORT qt_snprintf(char *str, int size, const char *format,...)
Definition: qtestcase.cpp:961
#define QTEST_ASSERT(cond)
Definition: qtestassert.h:53
quint16 index
static QString toNativeSeparators(const QString &pathName)
Returns pathName with the &#39;/&#39; separators converted to separators that are appropriate for the underly...
Definition: qdir.cpp:812
The QTest namespace contains all the functions and declarations that are related to the QTestLib tool...
static QString homePath()
Returns the absolute path of the user&#39;s home directory.
Definition: qdir.cpp:1942