diff options
Diffstat (limited to 'tests/manual/x11vkbtest/testreporter.cpp')
-rw-r--r-- | tests/manual/x11vkbtest/testreporter.cpp | 159 |
1 files changed, 159 insertions, 0 deletions
diff --git a/tests/manual/x11vkbtest/testreporter.cpp b/tests/manual/x11vkbtest/testreporter.cpp new file mode 100644 index 00000000..11e24524 --- /dev/null +++ b/tests/manual/x11vkbtest/testreporter.cpp @@ -0,0 +1,159 @@ +/**************************************************************************** +** +** Copyright (C) 2019 The Qt Company Ltd. +** Contact: https://www.qt.io/licensing/ +** +** This file is part of the Qt Virtual Keyboard module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:GPL$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and The Qt Company. For licensing terms +** and conditions see https://www.qt.io/terms-conditions. For further +** information use the contact form at https://www.qt.io/contact-us. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3 or (at your option) any later version +** approved by the KDE Free Qt Foundation. The licenses are as published by +** the Free Software Foundation and appearing in the file LICENSE.GPL3 +** included in the packaging of this file. Please review the following +** information to ensure the GNU General Public License requirements will +** be met: https://www.gnu.org/licenses/gpl-3.0.html. +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#include <QFile> +#include <QTextStream> +#include <QVectorIterator> +#include <QTextStream> +#include "testreporter.h" +#include "testbase.h" +#include "colors.h" +#include "startclose.h" + +namespace { +const QString KReport_CSV_File = "result.csv"; +const QString KCSV_Column_Separator = ";"; +} + +TestReporter::TestReporter(QObject *parent) : QObject(parent) +{ +} + +void TestReporter::startMemoryReport() +{ + QFile file(KReport_CSV_File); + if (file.open(QIODevice::WriteOnly)) { + QTextStream stream(&file); + stream << "Time" << KCSV_Column_Separator; + stream << "Process Memory size" << KCSV_Column_Separator << endl; + file.close(); + } +} + +void TestReporter::printTestResultsToCSV(const QVector<TestBase *> &tests) const +{ + QFile file(KReport_CSV_File); + if (file.open(QIODevice::WriteOnly | QIODevice::Append)) { + QTextStream stream(&file); + + stream << endl; + qint64 timeElapsed = 0; + quint8 passed = 0; + quint8 failed = 0; + bool currentTestIsStartClose = true; + + for (auto test : tests) { + if (nullptr == qobject_cast<StartClose*>(test)) { + currentTestIsStartClose = false; + if (test->passed()) { + stream << "PASS" << KCSV_Column_Separator; + passed++; + } else { + stream << "FAIL" << KCSV_Column_Separator; + failed++; + } + } + stream << test->testName() << KCSV_Column_Separator + << test->timeElapsed() << "s" << endl; + + QString extraInfo = test->reportResult(); + if (!extraInfo.isEmpty()) { + extraInfo.replace(QString(": "), QString(KCSV_Column_Separator)); + stream << extraInfo << endl; + } + timeElapsed = timeElapsed + test->timeElapsed(); + + if (currentTestIsStartClose) { + stream << endl; + } + } + + stream << endl; + stream << "Totals" << KCSV_Column_Separator << passed << " passed " + << KCSV_Column_Separator << failed << " failed" + << KCSV_Column_Separator << timeElapsed << "s"; + stream << endl; + file.close(); + } +} + +void TestReporter::printMemoryResultToCSV(QString minPeakMemoryReport) const +{ + QFile file(KReport_CSV_File); + + if (file.open(QIODevice::WriteOnly | QIODevice::Append)) { + QTextStream stream(&file); + minPeakMemoryReport.replace(QString(": "), QString(KCSV_Column_Separator)); + stream << minPeakMemoryReport << endl; + file.close(); + } +} + +void TestReporter::printTestResultToConsole(const QVector<TestBase *> &tests) const +{ + QTextStream stream(stdout); + + qint64 timeElapsed = 0; + quint8 passed = 0; + quint8 failed = 0; + + for (auto test : tests) { + if (nullptr == qobject_cast<StartClose*>(test)) { + if (test->passed()) { + stream << FBold(FGreen("PASS: ")); + passed++; + } else { + stream << FBold(FRed("FAIL:")); + failed++; + } + } + stream << test->testName() << " " << test->timeElapsed() << "s" << endl; + QString extraInfo = test->reportResult(); + if (!extraInfo.isEmpty()) { + stream << extraInfo << endl; + } + + timeElapsed = timeElapsed + test->timeElapsed(); + } + + stream << "Totals: " << passed << " passed, " << failed << " failed. " << timeElapsed << "s"; + stream << endl; +} + +void TestReporter::currentMemUsage(const quint64 timeElapsed, const ulong memSize) const +{ + QFile file(KReport_CSV_File); + + if (file.open(QIODevice::WriteOnly | QIODevice::Append)) { + QTextStream stream(&file); + stream << timeElapsed << "s" << KCSV_Column_Separator; + stream << memSize << " KB" << KCSV_Column_Separator << endl; + file.close(); + } +} |