178 lines
6.8 KiB
C++
178 lines
6.8 KiB
C++
/*
|
|
* Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
// A stripped-down version of Chromium's chrome/test/perf/perf_test.cc.
|
|
// ResultsToString(), PrintResult(size_t value) and AppendResult(size_t value)
|
|
// have been modified. The remainder are identical to the Chromium version.
|
|
|
|
#include "webrtc/test/testsupport/perf_test.h"
|
|
|
|
#include <sstream>
|
|
#include <stdio.h>
|
|
|
|
namespace {
|
|
|
|
std::string ResultsToString(const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
const std::string& values,
|
|
const std::string& prefix,
|
|
const std::string& suffix,
|
|
const std::string& units,
|
|
bool important) {
|
|
// <*>RESULT <graph_name>: <trace_name>= <value> <units>
|
|
// <*>RESULT <graph_name>: <trace_name>= {<mean>, <std deviation>} <units>
|
|
// <*>RESULT <graph_name>: <trace_name>= [<value>,value,value,...,] <units>
|
|
|
|
// TODO(ajm): Use of a stream here may violate the style guide (depending on
|
|
// one's definition of "logging"). Consider adding StringPrintf-like
|
|
// functionality as in the original Chromium implementation.
|
|
std::ostringstream stream;
|
|
if (important) {
|
|
stream << "*";
|
|
}
|
|
stream << "RESULT " << measurement << modifier << ": " << trace << "= "
|
|
<< prefix << values << suffix << " " << units << std::endl;
|
|
return stream.str();
|
|
}
|
|
|
|
void PrintResultsImpl(const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
const std::string& values,
|
|
const std::string& prefix,
|
|
const std::string& suffix,
|
|
const std::string& units,
|
|
bool important) {
|
|
printf("%s", ResultsToString(measurement, modifier, trace, values,
|
|
prefix, suffix, units, important).c_str());
|
|
}
|
|
|
|
} // namespace
|
|
|
|
namespace webrtc {
|
|
namespace test {
|
|
|
|
void PrintResult(const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
size_t value,
|
|
const std::string& units,
|
|
bool important) {
|
|
std::ostringstream value_stream;
|
|
value_stream << value;
|
|
PrintResultsImpl(measurement, modifier, trace, value_stream.str(), "", "",
|
|
units, important);
|
|
}
|
|
|
|
void AppendResult(std::string& output,
|
|
const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
size_t value,
|
|
const std::string& units,
|
|
bool important) {
|
|
std::ostringstream value_stream;
|
|
value_stream << value;
|
|
output += ResultsToString(measurement, modifier, trace,
|
|
value_stream.str(),
|
|
"", "", units, important);
|
|
}
|
|
|
|
void PrintResult(const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
const std::string& value,
|
|
const std::string& units,
|
|
bool important) {
|
|
PrintResultsImpl(measurement, modifier, trace, value, "", "", units,
|
|
important);
|
|
}
|
|
|
|
void AppendResult(std::string& output,
|
|
const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
const std::string& value,
|
|
const std::string& units,
|
|
bool important) {
|
|
output += ResultsToString(measurement, modifier, trace, value, "", "", units,
|
|
important);
|
|
}
|
|
|
|
void PrintResultMeanAndError(const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
const std::string& mean_and_error,
|
|
const std::string& units,
|
|
bool important) {
|
|
PrintResultsImpl(measurement, modifier, trace, mean_and_error,
|
|
"{", "}", units, important);
|
|
}
|
|
|
|
void AppendResultMeanAndError(std::string& output,
|
|
const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
const std::string& mean_and_error,
|
|
const std::string& units,
|
|
bool important) {
|
|
output += ResultsToString(measurement, modifier, trace, mean_and_error,
|
|
"{", "}", units, important);
|
|
}
|
|
|
|
void PrintResultList(const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
const std::string& values,
|
|
const std::string& units,
|
|
bool important) {
|
|
PrintResultsImpl(measurement, modifier, trace, values,
|
|
"[", "]", units, important);
|
|
}
|
|
|
|
void AppendResultList(std::string& output,
|
|
const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
const std::string& values,
|
|
const std::string& units,
|
|
bool important) {
|
|
output += ResultsToString(measurement, modifier, trace, values,
|
|
"[", "]", units, important);
|
|
}
|
|
|
|
void PrintSystemCommitCharge(const std::string& test_name,
|
|
size_t charge,
|
|
bool important) {
|
|
PrintSystemCommitCharge(stdout, test_name, charge, important);
|
|
}
|
|
|
|
void PrintSystemCommitCharge(FILE* target,
|
|
const std::string& test_name,
|
|
size_t charge,
|
|
bool important) {
|
|
fprintf(target, "%s", SystemCommitChargeToString(test_name, charge,
|
|
important).c_str());
|
|
}
|
|
|
|
std::string SystemCommitChargeToString(const std::string& test_name,
|
|
size_t charge,
|
|
bool important) {
|
|
std::string trace_name(test_name);
|
|
std::string output;
|
|
AppendResult(output, "commit_charge", "", "cc" + trace_name, charge, "kb",
|
|
important);
|
|
return output;
|
|
}
|
|
|
|
} // namespace test
|
|
} // namespace webrtc
|