1/****************************************************************************
2**
3** Copyright (C) 2016 Intel Corporation.
4** Contact: https://www.qt.io/licensing/
5**
6** This file is part of the QtTest module of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial License Usage
10** Licensees holding valid commercial Qt licenses may use this file in
11** accordance with the commercial license agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and The Qt Company. For licensing terms
14** and conditions see https://www.qt.io/terms-conditions. For further
15** information use the contact form at https://www.qt.io/contact-us.
16**
17** GNU Lesser General Public License Usage
18** Alternatively, this file may be used under the terms of the GNU Lesser
19** General Public License version 3 as published by the Free Software
20** Foundation and appearing in the file LICENSE.LGPL3 included in the
21** packaging of this file. Please review the following information to
22** ensure the GNU Lesser General Public License version 3 requirements
23** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
24**
25** GNU General Public License Usage
26** Alternatively, this file may be used under the terms of the GNU
27** General Public License version 2.0 or (at your option) the GNU General
28** Public license version 3 or any later version approved by the KDE Free
29** Qt Foundation. The licenses are as published by the Free Software
30** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
31** included in the packaging of this file. Please review the following
32** information to ensure the GNU General Public License requirements will
33** be met: https://www.gnu.org/licenses/gpl-2.0.html and
34** https://www.gnu.org/licenses/gpl-3.0.html.
35**
36** $QT_END_LICENSE$
37**
38****************************************************************************/
39
40#include "qcsvbenchmarklogger_p.h"
41#include "qtestresult_p.h"
42#include "qbenchmark_p.h"
43
44QCsvBenchmarkLogger::QCsvBenchmarkLogger(const char *filename)
45 : QAbstractTestLogger(filename)
46{
47}
48
49QCsvBenchmarkLogger::~QCsvBenchmarkLogger() = default;
50
51void QCsvBenchmarkLogger::startLogging()
52{
53 // don't print anything
54}
55
56void QCsvBenchmarkLogger::stopLogging()
57{
58 // don't print anything
59}
60
61void QCsvBenchmarkLogger::enterTestFunction(const char *)
62{
63 // don't print anything
64}
65
66void QCsvBenchmarkLogger::leaveTestFunction()
67{
68 // don't print anything
69}
70
71void QCsvBenchmarkLogger::addIncident(QAbstractTestLogger::IncidentTypes, const char *, const char *, int)
72{
73 // don't print anything
74}
75
76void QCsvBenchmarkLogger::addBenchmarkResult(const QBenchmarkResult &result)
77{
78 const char *fn = QTestResult::currentTestFunction() ? QTestResult::currentTestFunction()
79 : "UnknownTestFunc";
80 const char *tag = QTestResult::currentDataTag() ? QTestResult::currentDataTag() : "";
81 const char *gtag = QTestResult::currentGlobalDataTag()
82 ? QTestResult::currentGlobalDataTag()
83 : "";
84 const char *filler = (tag[0] && gtag[0]) ? ":" : "";
85
86 const char *metric = QTest::benchmarkMetricName(result.metric);
87
88 char buf[1024];
89 // "function","[globaltag:]tag","metric",value_per_iteration,total,iterations
90 qsnprintf(buf, sizeof(buf), "\"%s\",\"%s%s%s\",\"%s\",%.13g,%.13g,%u\n",
91 fn, gtag, filler, tag, metric,
92 result.value / result.iterations, result.value, result.iterations);
93 outputString(buf);
94}
95
96void QCsvBenchmarkLogger::addMessage(QAbstractTestLogger::MessageTypes, const QString &, const char *, int)
97{
98 // don't print anything
99}
100