/* * 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 #include 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 : = // <*>RESULT : = {, } // <*>RESULT : = [,value,value,...,] // 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