--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/benchmarks/uimodels/GraphicsViewBenchmark/testautom/resultlogger.cpp Tue Feb 02 00:43:10 2010 +0200
@@ -0,0 +1,167 @@
+/****************************************************************************
+**
+** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
+** Contact: Nokia Corporation (qt-info@nokia.com)
+**
+** This file is part of the examples of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** No Commercial Usage
+** This file contains pre-release code and may not be distributed.
+** You may use this file in accordance with the terms and conditions
+** contained in the either Technology Preview License Agreement or the
+** Beta Release License Agreement.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Nokia gives you certain
+** additional rights. These rights are described in the Nokia Qt LGPL
+** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
+** package.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU
+** General Public License version 3.0 as published by the Free Software
+** Foundation and appearing in the file LICENSE.GPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU General Public License version 3.0 requirements will be
+** met: http://www.gnu.org/copyleft/gpl.html.
+**
+** If you are unsure which license is appropriate for your use, please
+** contact the sales department at http://qt.nokia.com/contact.
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+#include <QFile>
+#include <QTextStream>
+#include <QDebug>
+
+#include "resultlogger.h"
+#include "benchmarks.h"
+#include "benchmark.h"
+
+ResultLogger::ResultLogger()
+ : QObject(), m_testFunctions(), m_fileName(""), m_format()
+{
+}
+
+ResultLogger::~ResultLogger()
+{
+ writeEntriesToFile(m_fileName, m_format);
+
+ qDeleteAll(m_testFunctions);
+ m_testFunctions.clear();
+}
+
+void ResultLogger::setResultFileInformation(const QString &filename, ResultFormat format)
+{
+ m_fileName = filename;
+ m_format = format;
+}
+
+TestFunctionResult *ResultLogger::createTestFunctionResult(const QString &name)
+{
+ TestFunctionResult *tf = new TestFunctionResult();
+ tf->setName(name);
+ m_testFunctions.append(tf);
+ return tf;
+}
+
+TestFunctionResult *ResultLogger::getTestFunctionResult(const QString &name)
+{
+ for (int i = 0; i <m_testFunctions.count(); ++i) {
+ TestFunctionResult *tf = m_testFunctions.at(i);
+ if (tf->name() == name)
+ return m_testFunctions.at(i);
+ }
+ return 0;
+}
+
+void ResultLogger::writeEntriesToFile(const QString &filename, ResultFormat format)
+{
+ if(m_testFunctions.count() == 0)
+ return;
+
+ QTextStream *out = 0;
+ QFile file;
+
+ if (filename.length() > 0) {
+ file.setFileName(filename);
+ if (!file.open(QIODevice::WriteOnly | QIODevice::Text)) {
+ qWarning() << "Opening result file failed: " << filename;
+ return;
+ }
+
+ out = new QTextStream(&file);
+ }
+ else {
+ out = new QTextStream(stdout);
+ }
+
+ if (format == Xml) {
+ *out << "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?>\n";
+ *out << "<TestCase name=\"GraphicsViewBenchmark\">\n";
+ *out << QString("<Environment><QtVersion>%1</QtVersion><QTestVersion>%2</QTestVersion></Environment>\n").arg(QT_VERSION_STR).arg(QT_VERSION_STR).toAscii();
+ }
+ if (format == Xml || format == LightXml) {
+ for (int i = 0; i <m_testFunctions.count(); ++i) {
+ TestFunctionResult *tf = m_testFunctions.at(i);
+
+ *out << QString("<TestFunction name=\"%1\">\n").arg(tf->name());
+
+ Benchmarks* benchmarks = tf->benchmarks();
+
+ if (tf->errors().length() == 0 &&
+ (benchmarks && benchmarks->count() <= 0)) {
+ *out << "<Incident type=\"pass\" file=\"\" line=\"0\"/>\n";
+ }
+ else if (tf->errors().length() > 0) {
+ *out << "<Incident type=\"fail\" file=\"\" line=\"0\">\n";
+ *out << "<DataTag><![CDATA[ message ]]></DataTag>\n";
+ *out << "<Description><![CDATA[";
+ QStringList &errors = tf->errors();
+ for (int e = 0; e < errors.length(); ++e)
+ *out << errors.at(e) << " ";
+ *out << "]]></Description>\n";
+ *out << "</Incident>\n";
+ }
+
+ for (int j = 0; j < benchmarks->count(); ++j) {
+ Benchmark *bm = benchmarks->at(j);
+ *out << QString("<BenchmarkResult metric=\"walltime\" tag=\"%1\" value=\"%2\" iterations=\"1\"/>\n").arg(bm->benchmarkStr()).arg(bm->value(), 0, 'f', 2);
+ }
+
+ *out << "</TestFunction>\n";
+ }
+ *out << "<TestFunction name=\"cleanupTestCase\"><Incident type=\"pass\" file=\"\" line=\"0\"/></TestFunction>\n";
+ }
+ else {
+ for (int i = 0; i <m_testFunctions.count(); ++i) {
+ TestFunctionResult *tf = m_testFunctions.at(i);
+
+ QStringList &errors = tf->errors();
+ for (int e = 0; e < errors.length(); ++e)
+ *out << errors.at(e) << " ";
+ if (errors.length() > 0)
+ *out << "\n";
+
+ Benchmarks* benchmarks = tf->benchmarks();
+ for (int j = 0; j < benchmarks->count(); ++j) {
+ *out << tf->name() << " " << benchmarks->at(j)->benchmarkStr() << " " << QString("%1").arg(benchmarks->at(j)->value(), 0, 'f', 2) << "\n";
+ }
+ }
+ }
+ if (format == Xml) {
+ *out << "</TestCase>\n";
+ }
+
+ delete out;
+ file.close();
+}