summaryrefslogtreecommitdiffstats
path: root/src/testlib/qcsvbenchmarklogger.cpp
diff options
context:
space:
mode:
authorThiago Macieira <thiago.macieira@intel.com>2013-12-20 11:14:04 -0800
committerThe Qt Project <gerrit-noreply@qt-project.org>2014-02-14 00:34:25 +0100
commit8dcb72fd1e2c17ad000474496b6d000580e0a943 (patch)
tree7e210404d51d2aff3fc6cdd92938071701acc0b1 /src/testlib/qcsvbenchmarklogger.cpp
parent539196689e806f8c175bb50343a4dc2cab52e838 (diff)
Add a CSV logging feature to the benchlib
This is only useful for logging benchmarks, since it won't print test passes, failures, etc. It's useful for importing to spreadsheets to do number-crunching. [ChangeLog][QtTest]Added a CSV logging mode that is suitable for importing benchmark results into spreadsheets. This can be enabled by the -csv option on the command-line. The CSV logging mode will not print test failures, debug messages, warnings, etc. Change-Id: I245d6f86bb380645c9bc0d748cf474b3ed42cab8 Reviewed-by: Sergio Ahumada <sahumada@blackberry.com> Reviewed-by: Jason McDonald <macadder1@gmail.com>
Diffstat (limited to 'src/testlib/qcsvbenchmarklogger.cpp')
-rw-r--r--src/testlib/qcsvbenchmarklogger.cpp103
1 files changed, 103 insertions, 0 deletions
diff --git a/src/testlib/qcsvbenchmarklogger.cpp b/src/testlib/qcsvbenchmarklogger.cpp
new file mode 100644
index 0000000000..ae5c3183dc
--- /dev/null
+++ b/src/testlib/qcsvbenchmarklogger.cpp
@@ -0,0 +1,103 @@
+/****************************************************************************
+**
+** Copyright (C) 2013 Intel Corporation
+** Contact: http://www.qt-project.org/legal
+**
+** This file is part of the QtTest module of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** 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 Digia. For licensing terms and
+** conditions see http://qt.digia.com/licensing. For further information
+** use the contact form at http://qt.digia.com/contact-us.
+**
+** 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, Digia gives you certain additional
+** rights. These rights are described in the Digia Qt LGPL Exception
+** version 1.1, 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.
+**
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+#include "qcsvbenchmarklogger_p.h"
+#include "qtestresult_p.h"
+#include "qbenchmark_p.h"
+
+QCsvBenchmarkLogger::QCsvBenchmarkLogger(const char *filename)
+ : QAbstractTestLogger(filename)
+{
+}
+
+QCsvBenchmarkLogger::~QCsvBenchmarkLogger()
+{
+}
+
+void QCsvBenchmarkLogger::startLogging()
+{
+ // don't print anything
+}
+
+void QCsvBenchmarkLogger::stopLogging()
+{
+ // don't print anything
+}
+
+void QCsvBenchmarkLogger::enterTestFunction(const char *)
+{
+ // don't print anything
+}
+
+void QCsvBenchmarkLogger::leaveTestFunction()
+{
+ // don't print anything
+}
+
+void QCsvBenchmarkLogger::addIncident(QAbstractTestLogger::IncidentTypes, const char *, const char *, int)
+{
+ // don't print anything
+}
+
+void QCsvBenchmarkLogger::addBenchmarkResult(const QBenchmarkResult &result)
+{
+ const char *fn = QTestResult::currentTestFunction() ? QTestResult::currentTestFunction()
+ : "UnknownTestFunc";
+ const char *tag = QTestResult::currentDataTag() ? QTestResult::currentDataTag() : "";
+ const char *gtag = QTestResult::currentGlobalDataTag()
+ ? QTestResult::currentGlobalDataTag()
+ : "";
+ const char *filler = (tag[0] && gtag[0]) ? ":" : "";
+
+ const char *metric = QTest::benchmarkMetricName(result.metric);
+
+ char buf[1024];
+ // "function","[globaltag:]tag","metric",value_per_iteration,total,iterations
+ qsnprintf(buf, sizeof(buf), "\"%s\",\"%s%s%s\",\"%s\",%.13g,%.13g,%u\n",
+ fn, gtag, filler, tag, metric,
+ result.value / result.iterations, result.value, result.iterations);
+ outputString(buf);
+}
+
+void QCsvBenchmarkLogger::addMessage(QAbstractTestLogger::MessageTypes, const QString &, const char *, int)
+{
+ // don't print anything
+}