205 lines
7.2 KiB
C++
205 lines
7.2 KiB
C++
// Copyright 2013 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "testing/perf/perf_test.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
#include "base/logging.h"
|
|
#include "base/strings/string_number_conversions.h"
|
|
#include "base/strings/stringprintf.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>
|
|
return base::StringPrintf("%sRESULT %s%s: %s= %s%s%s %s\n",
|
|
important ? "*" : "", measurement.c_str(), modifier.c_str(),
|
|
trace.c_str(), prefix.c_str(), values.c_str(), suffix.c_str(),
|
|
units.c_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) {
|
|
fflush(stdout);
|
|
printf("%s", ResultsToString(measurement, modifier, trace, values,
|
|
prefix, suffix, units, important).c_str());
|
|
fflush(stdout);
|
|
}
|
|
|
|
} // namespace
|
|
|
|
namespace perf_test {
|
|
|
|
void PrintResult(const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
size_t value,
|
|
const std::string& units,
|
|
bool important) {
|
|
PrintResultsImpl(measurement,
|
|
modifier,
|
|
trace,
|
|
base::UintToString(static_cast<unsigned int>(value)),
|
|
std::string(),
|
|
std::string(),
|
|
units,
|
|
important);
|
|
}
|
|
|
|
void PrintResult(const std::string& measurement,
|
|
const std::string& modifier,
|
|
const std::string& trace,
|
|
double value,
|
|
const std::string& units,
|
|
bool important) {
|
|
PrintResultsImpl(measurement,
|
|
modifier,
|
|
trace,
|
|
base::DoubleToString(value),
|
|
std::string(),
|
|
std::string(),
|
|
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) {
|
|
output += ResultsToString(
|
|
measurement,
|
|
modifier,
|
|
trace,
|
|
base::UintToString(static_cast<unsigned int>(value)),
|
|
std::string(),
|
|
std::string(),
|
|
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,
|
|
std::string(),
|
|
std::string(),
|
|
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,
|
|
std::string(),
|
|
std::string(),
|
|
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",
|
|
std::string(),
|
|
"cc" + trace_name,
|
|
charge,
|
|
"kb",
|
|
important);
|
|
return output;
|
|
}
|
|
|
|
} // namespace perf_test
|