| /* |
| * 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 |