tests/benchmarks/uimodels/GraphicsViewBenchmark/testautom/resultlogger.cpp
changeset 3 41300fa6a67c
--- /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();
+}