tests/benchmarks/uimodels/GraphicsViewBenchmark/testautom/resultlogger.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 02 Sep 2010 21:20:32 +0300
changeset 34 a33bf25e6f72
parent 3 41300fa6a67c
permissions -rw-r--r--
Revision: 201033 Kit: 201035

/****************************************************************************
**
** 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();
}